diff options
| -rw-r--r-- | src/backend/replication/logical/launcher.c | 9 | ||||
| -rw-r--r-- | src/bin/pg_upgrade/server.c | 15 | 
2 files changed, 13 insertions, 11 deletions
| diff --git a/src/backend/replication/logical/launcher.c b/src/backend/replication/logical/launcher.c index 33f07f674d9..122db0bb134 100644 --- a/src/backend/replication/logical/launcher.c +++ b/src/backend/replication/logical/launcher.c @@ -925,7 +925,14 @@ ApplyLauncherRegister(void)  {  	BackgroundWorker bgw; -	if (max_logical_replication_workers == 0) +	/* +	 * The logical replication launcher is disabled during binary upgrades, to +	 * prevent logical replication workers from running on the source cluster. +	 * That could cause replication origins to move forward after having been +	 * copied to the target cluster, potentially creating conflicts with the +	 * copied data files. +	 */ +	if (max_logical_replication_workers == 0 || IsBinaryUpgrade)  		return;  	memset(&bgw, 0, sizeof(bgw)); diff --git a/src/bin/pg_upgrade/server.c b/src/bin/pg_upgrade/server.c index 64b24270e38..91bcb4dbc7e 100644 --- a/src/bin/pg_upgrade/server.c +++ b/src/bin/pg_upgrade/server.c @@ -248,19 +248,14 @@ start_postmaster(ClusterInfo *cluster, bool report_and_exit_on_error)  	 * invalidation of slots during the upgrade. We set this option when  	 * cluster is PG17 or later because logical replication slots can only be  	 * migrated since then. Besides, max_slot_wal_keep_size is added in PG13. -	 * -	 * Use max_logical_replication_workers as 0 to prevent a startup of the -	 * logical replication launcher while upgrading because it may start apply -	 * workers that could start receiving changes from the publisher before -	 * the physical files are put in place, causing corruption on the new -	 * cluster upgrading to.  Like the previous parameter, this is set only -	 * when a cluster is PG17 or later as logical slots can only be migrated -	 * since this version.  	 */  	if (GET_MAJOR_VERSION(cluster->major_version) >= 1700) -		appendPQExpBufferStr(&pgoptions, " -c max_slot_wal_keep_size=-1 -c max_logical_replication_workers=0"); +		appendPQExpBufferStr(&pgoptions, " -c max_slot_wal_keep_size=-1"); -	/* Use -b to disable autovacuum. */ +	/* +	 * Use -b to disable autovacuum and logical replication launcher +	 * (effective in PG17 or later for the latter). +	 */  	snprintf(cmd, sizeof(cmd),  			 "\"%s/pg_ctl\" -w -l \"%s/%s\" -D \"%s\" -o \"-p %d -b%s %s%s\" start",  			 cluster->bindir, | 
