Re: POC: enable logical decoding when wal_level = 'replica' without a server restart

From: Peter Smith <smithpb2250(at)gmail(dot)com>
To: Masahiko Sawada <sawada(dot)mshk(at)gmail(dot)com>
Cc: Amit Kapila <amit(dot)kapila16(at)gmail(dot)com>, shveta malik <shveta(dot)malik(at)gmail(dot)com>, "Hayato Kuroda (Fujitsu)" <kuroda(dot)hayato(at)fujitsu(dot)com>, Ashutosh Bapat <ashutosh(dot)bapat(dot)oss(at)gmail(dot)com>, Shlok Kyal <shlok(dot)kyal(dot)oss(at)gmail(dot)com>, Bertrand Drouvot <bertranddrouvot(dot)pg(at)gmail(dot)com>, PostgreSQL-development <pgsql-hackers(at)postgresql(dot)org>
Subject: Re: POC: enable logical decoding when wal_level = 'replica' without a server restart
Date: 2025-10-27 00:53:55
Message-ID: CAHut+PuPJw5QJTxSdpK_M7buYgsgXQFKNBp7+pXGZxN1VzUcVQ@mail.gmail.com
Views: Whole Thread | Raw Message | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

Hi Sawada.

A couple of comments for v22-0001.

======

1.
+ /*
+ * We don't need this warning message when wal_level >= 'replica' since
+ * logical decoding is automatically enabled up on a logical slot
+ * creation.
+ */
+ if (wal_level == WAL_LEVEL_MINIMAL)
ereport(WARNING,
(errcode(ERRCODE_OBJECT_NOT_IN_PREREQUISITE_STATE),
- errmsg("\"wal_level\" is insufficient to publish logical changes"),
- errhint("Set \"wal_level\" to \"logical\" before creating subscriptions.")));
+ errmsg("logical decoding must be enabled to publish logical changes"),
+ errhint("Before creating subscriptions, set \"wal_level\" >=
\"logical\" or create a logical replication slot when \"wal_level\" =
\"replica\".")));

1a.
Sorry, for repeating the same question about the HINT message, but
AFAICT I did not yet notice any reply to directly reject or address my
question.

Basically, I felt the errhint part that says "...or create a logical
replication slot when wal_level = replica." is overkill, because
creating the subscription will do that anyway.
In other words, we don't need to tell the user this is needed "Before
creating subscriptions". So, I thought the only requirement to be able
to publish a subscription is for wal_level >= replica.

SUGGESTION
errhint("Before creating subscriptions, set \"wal_level\" >= \"replica\".")

~~

1b.
Since wal_level needs to be >= replica, the condition for this WARNING
might be better to be written as:
if (wal_level < WAL_LEVEL_REPLICA)

~~

1c.
Now that the condition for this warning was slightly changed, there
seems to be no test case anymore for this WARNING. Isn't it better to
still have a test case for this?

======
Kind Regards,
Peter Smith.
Fujitsu Australia

In response to

Browse pgsql-hackers by date

  From Date Subject
Next Message Chao Li 2025-10-27 01:27:58 Re: Optimize LISTEN/NOTIFY
Previous Message Mihail Nikalayeu 2025-10-27 00:25:18 Re: Cannot log in to CommitFest due to cool-off period