pgbench: When using pipelining only do PQconsumeInput() when necessary.
authorAndres Freund <andres@anarazel.de>
Thu, 5 Aug 2021 02:19:44 +0000 (19:19 -0700)
committerAndres Freund <andres@anarazel.de>
Thu, 5 Aug 2021 02:19:44 +0000 (19:19 -0700)
commit87bff68840d542011ed8f60427502fb90fdf2873
treee67daa4b9845c67731a96d765fdeb770cedee930
parent1bc8e7b0991c1eae5fa6dc2d29bb2280efb52740
pgbench: When using pipelining only do PQconsumeInput() when necessary.

Up to now we did a PQconsumeInput() for each pipelined query, asking the OS
for more input - which it often won't have, as all results might already have
been sent. That turns out to have a noticeable performance impact.

Alvaro Herrera reviewed the idea to add the PQisBusy() check, but not this
concrete patch.

Author: Andres Freund <andres@anarazel.de>
Discussion: https://postgr.es/m/20210720180039.23rivhdft3l4mayn@alap3.anarazel.de
Backpatch: 14, where libpq/pgbench pipelining was introduced.
src/bin/pgbench/pgbench.c