> On Mar 5, 2026, at 19:34, Zhijie Hou (Fujitsu) <[email protected]> wrote:
> 
> On Thursday, March 5, 2026 1:48 PM shveta malik <[email protected]> 
> wrote:
>> 
>> On Thu, Mar 5, 2026 at 9:35 AM shveta malik <[email protected]>
>> wrote:
>>> 
>>> On Thu, Mar 5, 2026 at 8:16 AM Zhijie Hou (Fujitsu)
>>> <[email protected]> wrote:
>>>> 
>>>> 
>>>> Here is V10 patch set which addressed all comments.
>>>> 
>>> 
>>> Thank You. Please find a few comments on 001:
>>> 
>> 
>> A concern in 002:
>> 
>> I realized that below might not be the correct logic to avoid overwriting
>> sequences at sub which are already at latest values.
>> 
>> + /*
>> + * Skip synchronization if the local sequence value is already ahead of
>> + * the publisher's value.
>> ...
>> + */
>> + if (local_last_value > seqinfo->last_value) { ereport(WARNING,
>> + errcode(ERRCODE_OBJECT_NOT_IN_PREREQUISITE_STATE),
>> + errmsg("skipped synchronizing the sequence \"%s.%s\"",
>> +    seqinfo->nspname, seqinfo->seqname), errdetail("The local
>> + last_value %lld is ahead of the one on publisher",
>> +   (long long int) local_last_value));
>> +
>> + return COPYSEQ_NO_DRIFT;
>> + }
>> 
>> 
>> A sequence could be descending one too and thus we may wrongly end up
>> avoiding synchronization. We should first check if it is descending or 
>> ascending
>> (perhaps by checking if increment_by < 0 or >0), then decide to manage
>> conflict.
> 
> Thanks for catching this, I changed it to check the increment before 
> reporting warning.
> 
> Best Regards,
> Hou zj

Hi,

I just started reviewing this patch and wanted to first discuss the design.

The current approach introduces a long-lived sync worker for any subscription 
that has at least one sequence. I noticed a previous email suggesting that this 
approach is “acceptable”, but it still seems like a big runtime cost.

What I had in mind instead is whether we could extend the WAL decoding protocol 
to send RM_SEQ_ID over the logical replication stream, so that sequence 
synchronization becomes part of logical replication itself. That would make it 
essentially event-driven and close to zero cost at runtime, rather than relying 
on periodic polling.

There is also one case I haven’t seen discussed yet. Suppose the standby side 
inserts a tuple into a table that is under logical replication. This might not 
immediately cause a tuple-level replication conflict, but it could advance the 
sequence locally. In that case, the standby sequence could diverge from the 
primary sequence and remain out of sync indefinitely. How should that situation 
be handled?

Best regards,
--
Chao Li (Evan)
HighGo Software Co., Ltd.
https://www.highgo.com/






Reply via email to