Re: Confused comment about drop replica identity index - Mailing list pgsql-hackers

From Euler Taveira
Subject Re: Confused comment about drop replica identity index
Date
Msg-id 41e5697a-b7eb-45d7-9f7b-d802d3fdbcf6@www.fastmail.com
Whole thread Raw
In response to Re: Confused comment about drop replica identity index  (Michael Paquier <michael@paquier.xyz>)
List pgsql-hackers
On Thu, Dec 16, 2021, at 8:55 PM, Michael Paquier wrote:
On Thu, Dec 16, 2021 at 03:08:46PM -0300, Alvaro Herrera wrote:
> Hmm, so if a table has REPLICA IDENTITY INDEX and there is a publication
> with an explicit column list, then we need to forbid the DROP INDEX for
> that index.

Hmm.  I have not followed this thread very closely.

> I wonder why don't we just forbid DROP INDEX of an index that's been
> defined as replica identity.  It seems quite silly an operation to
> allow.
It would avoid pilot errors.

The commit logs talk about b23b0f55 here for this code, to ease the
handling of relcache entries for rd_replidindex.  07cacba is the
origin of the logic (see RelationGetIndexList).  Andres?

I don't think that this is really an argument against putting more
restrictions as anything that deals with an index drop, including the
internal ones related to constraints, would need to go through
index_drop(), and new features may want more restrictions in place as
you say.

Now, I don't see a strong argument in changing this behavior either
(aka I have not looked at what this implies for the new publication
types), and we still need to do something for the comment/docs in
existing branches, anyway.  So I would still fix this gap as a first
step, then deal with the rest on HEAD as necessary.

I've never understand the weak dependency between the REPLICA IDENTITY and the
index used by it. I'm afraid we will receive complaints about this unexpected
behavior (my logical replication setup is broken because I dropped an index) as
far as new logical replication features are added.  Row filtering imposes some
restrictions in UPDATEs and DELETEs (an error message is returned and the
replication stops) if a column used in the expression isn't part of the REPLICA
IDENTITY anymore.

It seems we already have some code in RangeVarCallbackForDropRelation() that
deals with a system index error condition. We could save a syscall and provide
a test for indisreplident there.

If this restriction is undesirable, we should at least document this choice and
probably emit a WARNING for DROP INDEX.


--
Euler Taveira

pgsql-hackers by date:

Previous
From: Michael Paquier
Date:
Subject: Re: Confused comment about drop replica identity index
Next
From: Jacob Champion
Date:
Subject: Re: Transparent column encryption