> On Jan 2, 2026, at 00:31, Daniil Davydov <[email protected]> wrote:
>
> Hi,
>
> On Wed, Dec 31, 2025 at 9:32 AM Chao Li <[email protected]> wrote:
>>
>> You’re right that during CREATE_REPLICATION_SLOT, SnapBuildFindSnapshot()
>> ensures we don’t miss PREPARE records for prepared transactions that exist
>> at creation time.
>>
>> 1462aad2e introduced support for altering logical replication slot options,
>> including two_phase, after the slot has been created. The commit comment
>> says:
>> ```
>> Changing the 'two_phase' option for a subscription from 'true' to 'false'
>> is permitted only when there are no pending prepared transactions
>> corresponding to that subscription. Otherwise, the changes of already
>> prepared transactions can be replicated again along with their
>> corresponding
>> commit leading to duplicate data or errors.
>> ```
>>
>> true->false is not allowed, however false->true is permitted. So, I think
>> the old comment is still possible today:
>> ```
>> * Note that enabling this option after decoding has already advanced
>> * may result in missing PREPARE records for transactions that were
>> * prepared before the option was enabled.
>> ```
>>
>
> Hm, I still can't understand why the comment that you provided is correct.
>
> How can we "miss PREPARE records" if slot creation requires all prepared
> transactions to finish? The commit message says about risks during the
> change of the parameter "on the fly". But we are dealing with slot creation.
>
> --
> Best regards,
> Daniil Davydov
No problem, maybe I am wrong. Then please ignore my comment and wait for other
review comments.
Best regards,
--
Chao Li (Evan)
HighGo Software Co., Ltd.
https://www.highgo.com/