| From: | Chao Li <li(dot)evan(dot)chao(at)gmail(dot)com> |
|---|---|
| To: | Fujii Masao <masao(dot)fujii(at)gmail(dot)com> |
| Cc: | Yugo Nagata <nagata(at)sraoss(dot)co(dot)jp>, PostgreSQL-development <pgsql-hackers(at)postgresql(dot)org>, Rintaro Ikeda <ikedarintarof(at)oss(dot)nttdata(dot)com> |
| Subject: | Re: pgbench --continue-on-error: clarify TPS and failure reporting |
| Date: | 2026-06-18 12:45:29 |
| Message-ID: | 09361838-9213-4961-95A5-A0CD4AABF2DD@gmail.com |
| Views: | Whole Thread | Raw Message | Download mbox | Resend email |
| Thread: | |
| Lists: | pgsql-hackers |
> On Jun 18, 2026, at 17:40, Fujii Masao <masao(dot)fujii(at)gmail(dot)com> wrote:
>
> On Thu, Jun 18, 2026 at 3:25 PM Chao Li <li(dot)evan(dot)chao(at)gmail(dot)com> wrote:
>> Thanks for confirming the doc issue. The here comes a small doc patch.
>>
>> I also noticed there is a later paragraph about “latency” that also needs an update, it’s included in the patch as well.
>
> Thanks for the patch! The TPS-related changes look good to me.
>
> The latency of a successful transaction includes the entire time of
> - transaction execution with rollbacks and retries. The latency is measured
> - only for successful transactions and commands but not for failed
> transactions
> - or commands.
> + transaction execution with rollbacks and retries. The latency is measured
> + only for successful transactions and commands, except that failed
> + transactions are included in the simple average latency when the
> + <option>--continue-on-error</option> option is used.
>
> It doesn't seem that the behavior of the latency average in the main
> report depends on --continue-on-error itself. Instead, when neither
> --progress, --rate, nor --latency-limit is specified, the main
> report shows a simple latency average computed as the total benchmark
> duration divided by the number of successful and failed transactions,
> so failed transactions are included.
>
> On the other hand, when any of those options is specified, the
> latency average and latency stddev in the main report are based
> only on successful transactions. Likewise, the per-script and
> per-command latency statistics are measured only for successful
> transactions and commands.
>
> So how about something like this instead?
>
> -------------------------------
> <para>
> The latency of a successful transaction includes the entire time of
> - transaction execution with rollbacks and retries. The simple
> - <literal>latency average</literal> shown in the main report is computed from
> - the total benchmark duration divided by both successful and failed
> - transactions, and therefore includes failed transactions. In contrast,
> - detailed latency statistics, including the per-script and per-command
> - reports, are measured only for successful transactions and commands, not
> - for failed transactions or commands.
> + transaction execution with rollbacks and retries. In the main report, when
> + neither <option>--progress</option>, <option>--rate</option>, nor
> + <option>--latency-limit</option> is specified, the
> + <literal>latency average</literal> is computed from the total benchmark
> + duration divided by both successful and failed transactions, and therefore
> + includes failed transactions. Otherwise, the <literal>latency
> average</literal>
> + and <literal>latency stddev</literal> shown in the main report are measured
> + only for successful transactions. Detailed latency statistics, including
> + the per-script and per-command reports, are also measured only for
> + successful transactions and commands, not for failed transactions or
> + commands.
> </para>
> -------------------------------
>
I feel that might be too detailed. Listing these three option names here could make the doc harder to read and maintain. When failures are included, the output line already says so explicitly:
```
latency average = 0.387 ms (including failures)
```
Can we simply say something like this?
```
<para>
The latency of a successful transaction includes the entire time of
transaction execution with rollbacks and retries. The latency is measured
only for successful transactions and commands, not for failed transactions
or commands, unless the report explicitly says that it includes failures.
</para>
```
Best regards,
--
Chao Li (Evan)
HighGo Software Co., Ltd.
https://www.highgo.com/
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Tender Wang | 2026-06-18 13:01:11 | Re: assertion failure with unique index + partitioning + join |
| Previous Message | Andrew Dunstan | 2026-06-18 12:17:47 | Re: BackgroundPsql swallowing errors on windows |