Thread: pgsql: Don't report stats in LogicalRepApplyLoop() when in xact.

pgsql: Don't report stats in LogicalRepApplyLoop() when in xact.

From
Andres Freund
Date:
Don't report stats in LogicalRepApplyLoop() when in xact.

pgstat_report_stat() is only supposed to be called outside of transactions. In
5891c7a8ed8 I added a pgstat_report_stat() call into LogicalRepApplyLoop()'s
timeout branch. While not commonly reached inside a transaction, it is
reachable (e.g. due to network bottlenecks or the sender being stalled / slow
for some reason).

To fix, add a !IsTransactionState() check.

No test added because there's no easy way to reproduce this case without
patching the code.

Reported-By: Erik Rijkers <er@xs4all.nl>
Discussion: https://postgr.es/m/b3463b8c-2328-dcac-0136-af95715493c1@xs4all.nl

Branch
------
master

Details
-------
https://git.postgresql.org/pg/commitdiff/0cf16cb8ca4853b084c40eca310c4c9c3ebf7e2a

Modified Files
--------------
src/backend/replication/logical/worker.c | 9 +++++++--
1 file changed, 7 insertions(+), 2 deletions(-)