From: | Alvaro Herrera <alvherre(at)alvh(dot)no-ip(dot)org> |
---|---|
To: | Justin Pryzby <pryzby(at)telsasoft(dot)com> |
Cc: | Amit Langote <amitlangote09(at)gmail(dot)com>, pgsql-hackers(at)lists(dot)postgresql(dot)org |
Subject: | Re: ALTER TABLE .. DETACH PARTITION CONCURRENTLY |
Date: | 2021-02-26 20:32:36 |
Message-ID: | 20210226203236.GA30377@alvherre.pgsql |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-hackers |
On 2021-Jan-10, Justin Pryzby wrote:
> On Fri, Jan 08, 2021 at 04:14:33PM -0300, Alvaro Herrera wrote:
> > > > I ended up with apparently broken constraint when running multiple loops around
> > > > a concurrent detach / attach:
> > > >
> > > > while psql -h /tmp postgres -c "ALTER TABLE p ATTACH PARTITION p1 FOR VALUES FROM (1)TO(2)" -c "ALTER TABLE p DETACH PARTITION p1 CONCURRENTLY"; do :; done&
> > > > while psql -h /tmp postgres -c "ALTER TABLE p ATTACH PARTITION p1 FOR VALUES FROM (1)TO(2)" -c "ALTER TABLE p DETACH PARTITION p1 CONCURRENTLY"; do :; done&
> > > >
> > > > "p1_check" CHECK (true)
> > > > "p1_i_check" CHECK (i IS NOT NULL AND i >= 1 AND i < 2)
> > >
> > > Not good.
> >
> > Haven't had time to investigate this problem yet.
>
> I guess it's because you commited the txn and released lock in the middle of
> the command.
Hmm, but if we take this approach, then we're still vulnerable to the
problem that somebody can do DETACH CONCURRENTLY and cancel the wait (or
crash the server), then mess up the state before doing DETACH FINALIZE:
when they cancel the wait, the lock will be released.
I think the right fix is to disallow any action on a partition which is
pending detach other than DETACH FINALIZE. (Didn't do that here.)
Here's a rebase to current sources; there are no changes from v5.
--
Álvaro Herrera Valdivia, Chile
"No hay ausente sin culpa ni presente sin disculpa" (Prov. francés)
Attachment | Content-Type | Size |
---|---|---|
v6-0001-Let-ALTER-TABLE-exec-routines-deal-with-the-relat.patch | text/x-diff | 3.6 KB |
v6-0002-ALTER-TABLE-.-DETACH-CONCURRENTLY.patch | text/x-diff | 92.7 KB |
From | Date | Subject | |
---|---|---|---|
Next Message | Andrew Dunstan | 2021-02-26 20:40:14 | Re: Allow matching whole DN from a client certificate |
Previous Message | Daniel Gustafsson | 2021-02-26 20:02:11 | authtype parameter in libpq |