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.
{
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();
}