On Sun, Sep 14, 2025 at 7:55 PM Amit Kapila <amit.kapil...@gmail.com> wrote: > > On Fri, Sep 12, 2025 at 11:18 PM Masahiko Sawada <sawada.m...@gmail.com> > wrote: > > > > On Thu, Sep 11, 2025 at 9:08 PM Amit Kapila <amit.kapil...@gmail.com> wrote: > > > > > > > > For the shutdown sequence, can't we think of resetting effective_wal > > > after a restart? > > > > Does it mean that effective_wal_level keeps 'logical' until the next > > server starts? > > > > Yes, IIUC, effective_wal_level is anyway a derived value based on > current wal_level and presence of logical slots. So, what will be the > impact if it is not accurate at shutdown?
I think there won't be an impact at shutdown time. I would rather be concerned that such behavior could confuse users. I think it would not be a rare situation where users enable and disable logical decoding by creating and dropping a temporary slot. If we keep effective_wal_level 'logical' in this case, users would want to somehow disable logical decoding as it could have a negative performance impact. There would be two ways for users to change it to 'replica': restart the server or create and drop a logical slot again. On the other hand, for users who dropped a non-temporary logical slot without an error or dropped the non-last temporary slot, logical decoding is disabled without other manual interventions. It could be pretty hard to assess the situation, resulting in having users always checking effective_wal_level after dropping a logical slot and doing extra steps to make the effective_wal_level 'replica'. Regards, -- Masahiko Sawada Amazon Web Services: https://aws.amazon.com