Commit 504c7175 authored by Fujii Masao's avatar Fujii Masao

Fix bug in handling of connections that pg_receivexlog creates.

Previously pg_receivexlog created new connection for WAL streaming
even though another connection which had been established to create
or delete the replication slot was being left. This caused the unused
connection to be left uselessly until pg_receivexlog exited.
This bug was introduced by the commit d9f38c7a.

This patch changes pg_receivexlog so that the connection for
the replication slot is reused for WAL streaming.

Andres Freund, slightly modified by me, reviewed by Michael Paquier
parent 5c38a1d4
......@@ -293,7 +293,8 @@ StreamLog(void)
/*
* Connect in replication mode to the server
*/
conn = GetConnection();
if (conn == NULL)
conn = GetConnection();
if (!conn)
/* Error message already written in GetConnection() */
return;
......@@ -345,6 +346,7 @@ StreamLog(void)
fsync_interval);
PQfinish(conn);
conn = NULL;
}
/*
......@@ -591,6 +593,11 @@ main(int argc, char **argv)
disconnect_and_exit(1);
}
/*
* Don't close the connection here so that subsequent StreamLog()
* can reuse it.
*/
while (true)
{
StreamLog();
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment