RE: Newly created replication slot may be invalidated by checkpoint
От | Vitaly Davydov |
---|---|
Тема | RE: Newly created replication slot may be invalidated by checkpoint |
Дата | |
Msg-id | 2b8b64-68dead00-1f-7a5e2c00@253164000 обсуждение исходный текст |
Ответ на | RE: Newly created replication slot may be invalidated by checkpoint ("Hayato Kuroda (Fujitsu)" <kuroda.hayato@fujitsu.com>) |
Список | pgsql-hackers |
Dear Hayato, > Would you have enough time to work on and fix the issue? > One idea is to compute the required LSN by the system at the slot checkpoint. This > partially follows what PG18/HEAD does but seems hacky and difficult to accept. I'm working on the issue. Give me, please, a couple of days to finalize my work. In short, I think to call ReplicationSlotsComputeRequiredLSN() right before slotsMinReqLSN assignment in CreateCheckPoint in 17 and earlier versions. At this moment, we already have a new redo lsn. I consider, that the WAL reservation happens when we assign restart_lsn to a slot. Taking into account this consideration, I distinguish two cases - WAL reservation happens before or after new redo ptr assignment. If we reserve the WAL after new redo ptr, it will protect the slot's reservation, as you've mentioned. The problem appears, when we reserve the WAL before a new redo ptr, but the update of XLogCtl->replicationSlotMinLSN was not yet hapenned. When we assign slotsMinReqLSN, we use XLogCtl->replicationSlotMinLSN. The call of ReplicationSlotsComputeRequiredLSN before slotsMinReqLSN assignment can help. It will be guaranteed, that those slots with WAL reservation before a new redo ptr will be protected by slotsMinReqLSN, but slots with wal reservation after a new redo ptr will be protected by the redo ptr. I think it is about the same as you proposed. These reasonings are applied to physical slots, but it seems to be ok for logical slots. One moment, I'm not sure, when we create a logical slot in recovery. In this case, GetXLogReplayRecPtr() is used. I'm not sure, that redo ptr will protect such slot in CreateRestartPoint. With best regards, Vitaly
В списке pgsql-hackers по дате отправления: