On Tuesday, August 12, 2025 5:01 PM Dilip Kumar <dilipbal...@gmail.com> wrote:

Hi,

> 
> On Tue, Aug 12, 2025 at 2:21 PM Amit Kapila <amit.kapil...@gmail.com>
> wrote:
> >
> > On Tue, Aug 12, 2025 at 2:06 PM shveta malik <shveta.ma...@gmail.com>
> wrote:
> > >
> > > 2)
> > > postgres=# create subscription sub2  connection 'dbname=postgres
> > > host=localhost user=shveta port=5433' publication pub2 WITH
> > > (retain_dead_tuples = false, max_conflict_retention_duration=1000);
> > > NOTICE:  created replication slot "sub2" on publisher CREATE
> > > SUBSCRIPTION
> > >
> > > Shall we give notice that max_conflict_retention_duration is ignored
> > > as retain_dead_tuples is false.
> > >
> >
> > How about disallowing this combination?
> 
> +1 to disallow that.

I think disallowing this case may not suffice, as users could initially set
(retain_dead_tuples=on, max_conflict_retention_duration=100) but later disable
retain_dead_tuples. This would result in the same state as
(retain_dead_tuples=off, max_conflict_retention_duration=100) unless we disallow
disabling rdt in this case as well.

So, do you think we should disallow both cases, or we only disallow setting
max_conflict_retention_duration for disabled retain_dead_tuples and give NOTICE
in another case ?

I personally prefer a consistent behavior, e.g., either we allow both cases and
give NOTICEs, or we disallow both cases. This is because, if the goal here to
prevent potential misconfigurations by users, the scenario where a user disables
retain_dead_tuples might also be considered a similar misconfiguration. So, I'm
a bit concerned that the benefits of imposing a partial restriction may not
outweigh the risk of generating inconsistent behavior. (And I did not see
similar precedent).

What do you think ?

Best Regards,
Hou zj

Reply via email to