Re: CREATE INDEX CONCURRENTLY does not index prepared xact's data

From: Noah Misch <noah(at)leadboat(dot)com>
To: Andrey Borodin <x4mmm(at)yandex-team(dot)ru>
Cc: Michael Paquier <michael(at)paquier(dot)xyz>, Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>, pgsql-bugs(at)lists(dot)postgresql(dot)org
Subject: Re: CREATE INDEX CONCURRENTLY does not index prepared xact's data
Date: 2021-07-19 18:10:05
Message-ID: 20210719181005.GB972361@gust.leadboat.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-bugs

On Mon, Jul 19, 2021 at 12:10:52PM +0500, Andrey Borodin wrote:
> > 19 июля 2021 г., в 05:30, Noah Misch <noah(at)leadboat(dot)com> написал(а):
> >
> > To fix $SUBJECT, it sounds like we need a way to identify a transaction,
> > usable as early as the transaction's first catalog access and remaining valid
> > until COMMIT PREPARED finishes. We may initially see a transaction as having
> > a VXID and no XID, then later need to wait for that transaction when it has
> > entered prepared state, having an XID and no VXID. How might we achieve that?
>
> PFA draft with vxid->xid mapping and subsequent wait for it. The patch, obviously, lacks a ton of comments explaining what is going on.
> We write actual VXID into dummy proc entries of prepared xact.
> When we wait for vxid we try to convert it to xid through real proc entry. If we cannot do so - we lookup in shared 2pc state. If vxid is not there - it means it is already gone and there's nothing to wait.

When the system reuses BackendId values, it reuses VXID values. In the
general case, two prepared transactions could exist simultaneously with the
same BackendId+LocalTransactionId. Hmm. It could be okay to have a small
probability that CIC waits on more transactions than necessary. Suppose we
have three PGPROC entries with the same VXID, two prepared transactions and
one regular transaction. Waiting for all three could be tolerable, though
avoiding that would be nice. Should we follow transactions differently to
avoid that?

In response to

Responses

Browse pgsql-bugs by date

  From Date Subject
Next Message Andrey Borodin 2021-07-19 18:41:28 Re: CREATE INDEX CONCURRENTLY does not index prepared xact's data
Previous Message Tom Lane 2021-07-19 14:49:28 Re: BUG #17113: Assert failed on calling a function fixed after an extension reload