Re: Conflict detection for update_deleted in logical replication
От | shveta malik |
---|---|
Тема | Re: Conflict detection for update_deleted in logical replication |
Дата | |
Msg-id | CAJpy0uDJ7YY0VYXqjYXK5CpkTaFT--GPm38_LWMjn555AFHWuw@mail.gmail.com обсуждение исходный текст |
Ответ на | Re: Conflict detection for update_deleted in logical replication (shveta malik <shveta.malik@gmail.com>) |
Ответы |
Re: Conflict detection for update_deleted in logical replication
|
Список | pgsql-hackers |
On Thu, Jul 24, 2025 at 9:12 AM shveta malik <shveta.malik@gmail.com> wrote: > > > 2) > + if (MySubscription->retaindeadtuples && > + FindMostRecentlyDeletedTupleInfo(localrel, remoteslot, > + > &conflicttuple.xmin, > + > &conflicttuple.origin, > + > &conflicttuple.ts) && > + conflicttuple.origin != replorigin_session_origin) > + type = CT_UPDATE_DELETED; > + else > + type = CT_UPDATE_MISSING; > > Shall the conflict be detected as update_deleted irrespective of origin? > On thinking more here, I think that we may have the possibility of UPDATE after DELETE from the same origin only when a publication selectively publishes certain operations. 1) Consider a publication that only publishes UPDATE and DELETE operations. On the publisher, we may perform operations like DELETE, INSERT, and UPDATE. On the subscriber, only DELETE and UPDATE events are received. In this case, should we treat the incoming UPDATE as update_deleted or update_missing? 2) Another topology could be: pub1 --> pub2 --> sub (origin=any) pub1 --> sub - pub1 publishing only DELETEs to pub2 and the same are published to sub. - pub1 publishing only UPDATEs to sub. Now, consider that on pub1, an UPDATE occurs first, followed by a DELETE. But on the sub, the events are received in reverse order: DELETE arrives before UPDATE. Since both operations originated from the same source (pub1), how delayed UPDATE's conflict should be interpreted? Should it be detected as update_deleted or update_missing? Logically, since the DELETE is the more recent operation, it should be the final one and UPDATE should be ignored. But if we detect it as update_missing, we might incorrectly apply the UPDATE. Thoughts? thanks Shveta
В списке pgsql-hackers по дате отправления: