]> git.ipfire.org Git - thirdparty/postgresql.git/commitdiff
Fix stale COPY progress during logical replication table sync
authorFujii Masao <fujii@postgresql.org>
Wed, 13 May 2026 02:44:31 +0000 (11:44 +0900)
committerFujii Masao <fujii@postgresql.org>
Wed, 13 May 2026 02:44:31 +0000 (11:44 +0900)
Previously, pg_stat_progress_copy in the subscriber could continue to show
the initial COPY operation for logical replication table synchronization as
active even after the data copy had finished. The stale progress entry
remained visible until synchronization caught up with the publisher.

This happened because the table synchronization code called BeginCopyFrom()
and CopyFrom(), but failed to call EndCopyFrom() afterward.

This commit fixes the issue by adding the missing EndCopyFrom() call so that
the COPY progress state in the subscriber is cleared as soon as the initial
data copy completes.

Backpatch to all supported branches.

Author: Shinya Kato <shinya11.kato@gmail.com>
Reviewed-by: Fujii Masao <masao.fujii@gmail.com>
Reviewed-by: ChangAo Chen <cca5507@qq.com>
Reviewed-by: Chao Li <li.evan.chao@gmail.com>
Discussion: https://postgr.es/m/CAOzEurQKuy3RiPkd=25PEwEzaqHuGvEOf=X7vaVzhgNjaukYzA@mail.gmail.com
Backpatch-through: 14

src/backend/replication/logical/tablesync.c

index eb7181142970026459e36c4f64b31f4c2cc51fee..a04b84ebc1dd52d0b24badd21162e51998502124 100644 (file)
@@ -1210,6 +1210,7 @@ copy_table(Relation rel)
 
        /* Do the copy */
        (void) CopyFrom(cstate);
+       EndCopyFrom(cstate);
 
        logicalrep_rel_close(relmapentry, NoLock);
 }