Fix hang after a flush message received.
authorTatsuo Ishii <ishii@postgresql.org>
Tue, 30 Jul 2024 09:17:57 +0000 (18:17 +0900)
committerTatsuo Ishii <ishii@postgresql.org>
Tue, 30 Jul 2024 09:29:26 +0000 (18:29 +0900)
Previously pgpool could hang after a flush message arrives. Consider
following scenario:

(1) backend sends a portal suspend message.
(2) pgool write it in the frontend write buffer. But not flush it.
(3) The frontend sends a flush message to pgpool.
(4) pgpool fowards the flush message to backend.
(5) Since there's no pending message in backend, nothing happen.
(6) The frontend waits for the portal suspend message from pgpool in vain.

To fix this, at (4) pgpool flushes data in the frontend write buffer
if some data remains (in this case the portal suspend message). Then
the frontend will send next request message to pgpool.

Discussion: https://github.com/pgpool/pgpool2/issues/59
Backpatch-through: master, 4.5, 4.4, 4.3, 4.2 and 4.1.

src/protocol/pool_proto_modules.c

index 7cba9776a75474787c9ff3a7aa248c5a78b95294..7725df65d38d9be884f90e61af396901aa661699 100644 (file)
@@ -2913,6 +2913,13 @@ ProcessFrontendResponse(POOL_CONNECTION * frontend,
                        {
                                if (fkind == 'H')
                                {
+                                       /*
+                                        * If data remains in the frontend write buffer, flush it
+                                        * now.
+                                        */
+                                       pool_flush(frontend);
+                                       elog(DEBUG5,
+                                                "pending data flushed to frontend due to a flush message");
                                        pool_set_doing_extended_query_message();
                                        pool_pending_message_set_flush_request();
                                }