Re: Track in pg_replication_slots the reason why slots conflict?

Поиск
Список
Период
Сортировка
От shveta malik
Тема Re: Track in pg_replication_slots the reason why slots conflict?
Дата
Msg-id CAJpy0uCEPaYFSjCkHk9EeO2o-TkPfBsgc8wpKZHj=uFCL=tVCw@mail.gmail.com
обсуждение исходный текст
Ответ на Re: Track in pg_replication_slots the reason why slots conflict?  (Isaac Morland <isaac.morland@gmail.com>)
Ответы Re: Track in pg_replication_slots the reason why slots conflict?  (Amit Kapila <amit.kapila16@gmail.com>)
Список pgsql-hackers
On Tue, Dec 26, 2023 at 7:35 PM Isaac Morland <isaac.morland@gmail.com> wrote:
>
> On Thu, 21 Dec 2023 at 09:26, Amit Kapila <amit.kapila16@gmail.com> wrote:
>
>>
>> A conflicting column where NULL indicates no conflict, and other
>> > values indicate the reason for the conflict, doesn't seem too bad.
>> >
>>
>> This is fine too.
>
>
> I prefer this option. There is precedent for doing it this way, for example in pg_stat_activity.wait_event_type.
>
> The most common test of this field is likely to be "is there a conflict" and it's better to write this as
"[fieldname]IS NOT NULL" than to introduce a magic constant. Also, it makes clear to future maintainers that this field
hasone purpose: saying what type of conflict there is, if any. If we find ourselves wanting to record a new
non-conflictstatus (no idea what that could be: "almost conflict"? "probably conflict soon"?) there would be less
temptationto break existing tests for "is there a conflict". 

+1 on using "[fieldname] IS NOT NULL"  to  find  "is there a conflict"

PFA the patch which attempts to implement this.

This patch changes the existing 'conflicting' field to
'conflicting_cause' in pg_replication_slots. This new field is always
NULL for physical slots (like the previous field conflicting), as well
as for those logical slots which are not invalidated.

thanks
Shveta

Вложения

В списке pgsql-hackers по дате отправления:

Предыдущее
От: Richard Guo
Дата:
Сообщение: Revise the Asserts added to bimapset manipulation functions
Следующее
От: Vitalijus Jefišovas
Дата:
Сообщение: PostgreSQL 16.1 dict_snowball.so: undefined symbol: CurrentMemoryContext