Re: logical replication syntax (was DROP SUBSCRIPTION, query cancellations and slot handling)

From: Masahiko Sawada <sawada(dot)mshk(at)gmail(dot)com>
To: Petr Jelinek <petr(dot)jelinek(at)2ndquadrant(dot)com>
Cc: Peter Eisentraut <peter(dot)eisentraut(at)2ndquadrant(dot)com>, Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>, Robert Haas <robertmhaas(at)gmail(dot)com>, Michael Paquier <michael(dot)paquier(at)gmail(dot)com>, PostgreSQL mailing lists <pgsql-hackers(at)postgresql(dot)org>
Subject: Re: logical replication syntax (was DROP SUBSCRIPTION, query cancellations and slot handling)
Date: 2017-05-09 08:51:40
Message-ID: CAD21AoDJ+3S_2KkPLqx2tQAOPj_RwV8E3X8U-wyHMuyBQ58YUw@mail.gmail.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

On Tue, May 9, 2017 at 5:39 PM, Petr Jelinek
<petr(dot)jelinek(at)2ndquadrant(dot)com> wrote:
> On 09/05/17 07:07, Peter Eisentraut wrote:
>> On 5/8/17 23:23, Peter Eisentraut wrote:
>>> The way this uses RESTRICT and CASCADE appears to be backwards from its
>>> usual meaning. Normally, CASCADE when dropping an object that is still
>>> used by others will cause those other objects to be dropped. The
>>> equivalent here would be DROP REPLICATION SLOT + CASCADE would drop the
>>> subscription.
>>>
>>> What we want to simulate instead is an "auto" dependency of the slot on
>>> the subscription. So you can drop the slot separately (subject to other
>>> restrictions), and it is dropped automatically when the subscription is
>>> dropped. To avoid that, you can disassociate the slot from the
>>> subscription, which you have implemented.
>>>
>>> I think we can therefore do without RESTRICT/CASCADE here. If a slot is
>>> associated with the subscription, it should be there when we drop the
>>> subscription. Otherwise, the user has to disassociate the slot and take
>>> care of it manually. So just keep the "cascade" behavior.
>>>
>>> Similarly, I wouldn't check first whether the slot exists. If the
>>> subscription is associated with the slot, it should be there.

IIUC in this design, for example if we mistakenly create a
subscription without creating replication slot and corresponding
replication slot doesn't exist on publisher, we cannot drop
subscription until we create corresponding replication slot manually.
Isn't it become a problem for user?

Regards,

--
Masahiko Sawada
NIPPON TELEGRAPH AND TELEPHONE CORPORATION
NTT Open Source Software Center

In response to

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Petr Jelinek 2017-05-09 08:54:31 Re: SUBSCRIPTIONS and pg_upgrade
Previous Message Petr Jelinek 2017-05-09 08:50:34 Re: snapbuild woes