Re: Logical Replication of sequences - Mailing list pgsql-hackers
From | Dilip Kumar |
---|---|
Subject | Re: Logical Replication of sequences |
Date | |
Msg-id | CAFiTN-uMY+h+13uDW8ZBQjkL5K+VeqUCEZsrSB3+ZMfEXKAynQ@mail.gmail.com Whole thread Raw |
In response to | Re: Logical Replication of sequences (Amit Kapila <amit.kapila16@gmail.com>) |
Responses |
Re: Logical Replication of sequences
|
List | pgsql-hackers |
On Tue, Oct 7, 2025 at 3:51 PM Amit Kapila <amit.kapila16@gmail.com> wrote: > > On Tue, Oct 7, 2025 at 2:21 PM Dilip Kumar <dilipbalaut@gmail.com> wrote: > > > > On Mon, Oct 6, 2025 at 4:33 PM vignesh C <vignesh21@gmail.com> wrote: > > > > > > On Mon, 6 Oct 2025 at 12:07, vignesh C <vignesh21@gmail.com> wrote: > > > > > > > > On Sat, 4 Oct 2025 at 21:24, Amit Kapila <amit.kapila16@gmail.com> wrote: > > > > > > > > > > On Tue, Sep 30, 2025 at 9:55 PM vignesh C <vignesh21@gmail.com> wrote: > > > > > > > > > > > > > > > > In the 0001 patch, pg_get_sequence_data() exposes two new fields > > > > > log_cnt and page_lsn. I see that the later subscriber-side patch uses > > > > > both, the first one in SetSequence(). It is not clear from the > > > > > comments or the commit message of 0001 why it is necessary to use > > > > > log_cnt when setting the sequence. Can you explain what the problem > > > > > will be if we don't use log_cnt during sequence sync? > > > > > > > > I thought to keep the log_cnt value the same value as the publisher. > > > > I have verified from the upgrade that we don't retain the log_cnt > > > > value after upgrade, even if we copy log_cnt, the value will not be > > > > retained. The attached > > > > v20251006-0001-Enhance-pg_get_sequence_data-function.patch has the > > > > changes to remove log_cnt. > > > > > > Here is the rebased remaining patches. > > > > While testing the patches with different combinations to make > > publications, I do not understand why we don't support ALL SEQUENCE > > with some table option, or is it future pending work. > > > > Yes, it is left for future similar to the cases like FOR SEQUENCE s1 > or FOR SEQUENCES IN SCHEMA. The key idea was to first support the > cases required for upgrade and we can later extend the feature after > some user feedback or separate discussion with -hackers to see what > others think. Does that sound reasonable to you? Yeah that's correct, I think the main use case for sequence synchronization is upgrade and it makes sense to use ALL TABLES/ALL SEQUENCES for upgrade. However, if a user is using selective tables for upgrade for now they might not be able to use ALL SEQUENCE and that should be fine as we are going to provide add on functionality. I have one more question: while testing the sequence sync, I found this behavior is documented as well[1], but what's the reasoning behind it? Why REFRESH PUBLICATION will synchronize only newly added sequences and need to use REFRESH PUBLICATION SEQUENCES to re-synchronize all sequences. I mean what will be the use case where users just want to synchronize the newly added sequences and not others? [1] + <para> + use <link linkend="sql-altersubscription-params-refresh-publication"> + <command>ALTER SUBSCRIPTION ... REFRESH PUBLICATION</command></link> + to synchronize only newly added sequences. + </para> + </listitem> + <listitem> + <para> + use <link linkend="sql-altersubscription-params-refresh-publication-sequences"> + <command>ALTER SUBSCRIPTION ... REFRESH PUBLICATION SEQUENCES</command></link> + to re-synchronize all sequences. + </para> -- Regards, Dilip Kumar Google
pgsql-hackers by date: