]> git.ipfire.org Git - thirdparty/postgresql.git/commit
pgbench: fix verbose error message corruption with multiple threads
authorFujii Masao <fujii@postgresql.org>
Thu, 14 May 2026 03:31:43 +0000 (12:31 +0900)
committerFujii Masao <fujii@postgresql.org>
Thu, 14 May 2026 03:31:43 +0000 (12:31 +0900)
commitf18fcd9a450b64184d74c3ce6cb6fd79a6499c9f
treecc586e647bb071d9a021055068ca381adcfbb52c
parentf4ba78081895d40ced104fc63914be7fd2e4372c
pgbench: fix verbose error message corruption with multiple threads

When pgbench runs with multiple threads and verbose error reporting is
enabled (--verbose-errors), multiple clients can build verbose error
messages concurrently. Previously, a function-local static
PQExpBuffer was used for these messages, causing the buffer to be
shared across threads. This was not thread-safe and could result in
corrupted or incorrect log output.

Fix this by using a local PQExpBufferData instead of a static buffer.
This keeps verbose error messages correct during concurrent execution.

Backpatch to v15, where this issue was introduced.

Author: Fujii Masao <masao.fujii@gmail.com>
Reviewed-by: Michael Paquier <michael@paquier.xyz>
Reviewed-by: Alex Guo <guo.alex.hengchen@gmail.com>
Reviewed-by: Chao Li <li.evan.chao@gmail.com>
Discussion: https://postgr.es/m/CAHGQGwER1AjGXpkKB9t9820NBhMQ_Ghv7=HsKeodUr3=SZsF4g@mail.gmail.com
Backpatch-through: 15
src/bin/pgbench/pgbench.c