aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPeter Eisentraut <peter_e@gmx.net>2017-05-01 10:18:09 -0400
committerPeter Eisentraut <peter_e@gmx.net>2017-05-01 10:18:09 -0400
commit9414e41ea703ea5fcc288bcf7dc000e53306896b (patch)
tree974069d514fb35f6c294f3e7c94dcfd2b3231fdf
parente180c8aa8caf5c55a273d4a8e6092e77ff3cff10 (diff)
downloadpostgresql-9414e41ea703ea5fcc288bcf7dc000e53306896b.tar.gz
postgresql-9414e41ea703ea5fcc288bcf7dc000e53306896b.zip
Fix logical replication launcher wake up and reset
After the logical replication launcher was told to wake up at commit (for example, by a CREATE SUBSCRIPTION command), the flag to wake up was not reset, so it would be woken up at every following commit as well. So fix that by resetting the flag. Also, we don't need to wake up anything if the transaction was rolled back. Just reset the flag in that case. Author: Masahiko Sawada <sawada.mshk@gmail.com> Reported-by: Fujii Masao <masao.fujii@gmail.com>
-rw-r--r--src/backend/access/transam/xact.c3
-rw-r--r--src/backend/replication/logical/launcher.c6
-rw-r--r--src/include/replication/logicallauncher.h2
3 files changed, 7 insertions, 4 deletions
diff --git a/src/backend/access/transam/xact.c b/src/backend/access/transam/xact.c
index 605639b0c3d..a3ff1b22f07 100644
--- a/src/backend/access/transam/xact.c
+++ b/src/backend/access/transam/xact.c
@@ -2138,7 +2138,7 @@ CommitTransaction(void)
AtEOXact_HashTables(true);
AtEOXact_PgStat(true);
AtEOXact_Snapshot(true, false);
- AtCommit_ApplyLauncher();
+ AtEOXact_ApplyLauncher(true);
pgstat_report_xact_timestamp(0);
CurrentResourceOwner = NULL;
@@ -2612,6 +2612,7 @@ AbortTransaction(void)
AtEOXact_ComboCid();
AtEOXact_HashTables(false);
AtEOXact_PgStat(false);
+ AtEOXact_ApplyLauncher(false);
pgstat_report_xact_timestamp(0);
}
diff --git a/src/backend/replication/logical/launcher.c b/src/backend/replication/logical/launcher.c
index f5058d5a9ac..09c87d7c53a 100644
--- a/src/backend/replication/logical/launcher.c
+++ b/src/backend/replication/logical/launcher.c
@@ -748,10 +748,12 @@ ApplyLauncherShmemInit(void)
* Wakeup the launcher on commit if requested.
*/
void
-AtCommit_ApplyLauncher(void)
+AtEOXact_ApplyLauncher(bool isCommit)
{
- if (on_commit_launcher_wakeup)
+ if (isCommit && on_commit_launcher_wakeup)
ApplyLauncherWakeup();
+
+ on_commit_launcher_wakeup = false;
}
/*
diff --git a/src/include/replication/logicallauncher.h b/src/include/replication/logicallauncher.h
index 0c2bf03a5fe..fb3c2f53709 100644
--- a/src/include/replication/logicallauncher.h
+++ b/src/include/replication/logicallauncher.h
@@ -22,6 +22,6 @@ extern Size ApplyLauncherShmemSize(void);
extern void ApplyLauncherShmemInit(void);
extern void ApplyLauncherWakeupAtCommit(void);
-extern void AtCommit_ApplyLauncher(void);
+extern void AtEOXact_ApplyLauncher(bool isCommit);
#endif /* LOGICALLAUNCHER_H */