Received: from malur.postgresql.org ([217.196.149.56]) by arkaria.postgresql.org with esmtps (TLS1.3) tls TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384 (Exim 4.96) (envelope-from ) id 1w9gPc-001e92-2W for pgsql-hackers@arkaria.postgresql.org; Mon, 06 Apr 2026 09:38:29 +0000 Received: from localhost ([127.0.0.1] helo=malur.postgresql.org) by malur.postgresql.org with esmtp (Exim 4.96) (envelope-from ) id 1w9gPb-007Z0H-0O for pgsql-hackers@arkaria.postgresql.org; Mon, 06 Apr 2026 09:38:27 +0000 Received: from makus.postgresql.org ([2001:4800:3e1:1::229]) by malur.postgresql.org with esmtps (TLS1.3) tls TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384 (Exim 4.96) (envelope-from ) id 1w9gPa-007Z08-0z for pgsql-hackers@lists.postgresql.org; Mon, 06 Apr 2026 09:38:27 +0000 Received: from fout-a4-smtp.messagingengine.com ([103.168.172.147]) by makus.postgresql.org with esmtps (TLS1.3) tls TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384 (Exim 4.98.2) (envelope-from ) id 1w9gPY-00000000pZM-2ZIX for pgsql-hackers@lists.postgresql.org; Mon, 06 Apr 2026 09:38:25 +0000 Received: from phl-compute-07.internal (phl-compute-07.internal [10.202.2.47]) by mailfout.phl.internal (Postfix) with ESMTP id 790DFEC011A; Mon, 6 Apr 2026 05:38:23 -0400 (EDT) Received: from phl-frontend-03 ([10.202.2.162]) by phl-compute-07.internal (MEProxy); Mon, 06 Apr 2026 05:38:23 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d= messagingengine.com; h=cc:cc:content-transfer-encoding :content-type:content-type:date:date:feedback-id:feedback-id :from:from:in-reply-to:in-reply-to:message-id:mime-version :reply-to:subject:subject:to:to:x-me-proxy:x-me-sender :x-me-sender:x-sasl-enc; s=fm2; t=1775468303; x=1775554703; bh=K Ud8DJHfC864jKhy92COhCeiTQA29j1PUfihYeC+m8g=; b=tNQum2rVyZ8T8pSk4 w9f9gIyWwzU2FvlQSEe05FrxFYRiVsLvJ8gPyN5MyohXkyt11ps/s77tfb02Fhd2 QUnPU9aYI3J+4c/YZhE6hQPIUqxD8KOQRtwJB2acmNPfRwEBQ6YUQovxeT2v2/s5 SY9qFCn5LUBUwEtXVJlphI/NY9CrFC4fTaDd6grVCieebfdHOq7uOUr6VCqiShq2 ioUvmD+HCY1rXSPT6JwhK2BAIXZBHmoYp4/NIrNdXFIkd5FIJ1lQXkCBIl9/zWkp qiftHZRxQPJnazGO1fcPPjga/UKcRg+d+y97eSZpR6ISZHImSAPh3SGeUpcWQzLj 22vmQ== X-ME-Sender: X-ME-Received: X-ME-Proxy-Cause: gggruggvucftvghtrhhoucdtuddrgeefhedrtddtgddujeefiecutefuodetggdotefrod ftvfcurfhrohhfihhlvgemucfhrghsthforghilhdpuffrtefokffrpgfnqfghnecuuegr ihhlohhuthemuceftddtnecusecvtfgvtghiphhivghnthhsucdlqddutddtmdenucfjug hrpeffhffvvefukfggtggugfgjsehtkeertddttdejnecuhfhrohhmpeetlhhvrghrohcu jfgvrhhrvghrrgcuoegrlhhvhhgvrhhrvgesrghlvhhhrdhnohdqihhprdhorhhgqeenuc ggtffrrghtthgvrhhnpedvkedtffduffdtffffheffhfejjefhgfeiueeukeejkeffgfdu fffhudffffeuveenucffohhmrghinhepvghnthgvrhhprhhishgvuggsrdgtohhmnecuve hluhhsthgvrhfuihiivgeptdenucfrrghrrghmpehmrghilhhfrhhomheprghlvhhhvghr rhgvsegrlhhvhhdrnhhoqdhiphdrohhrghdpnhgspghrtghpthhtohepkedpmhhouggvpe hsmhhtphhouhhtpdhrtghpthhtoheprghhsegthigsvghrthgvtgdrrghtpdhrtghpthht oheprghmihhtrdhkrghpihhlrgduieesghhmrghilhdrtghomhdprhgtphhtthhopegsoh gvkhgvfihurhhmodhpohhsthhgrhgvshesghhmrghilhdrtghomhdprhgtphhtthhopehm ihhhrghilhhnihhkrghlrgihvghusehgmhgrihhlrdgtohhmpdhrtghpthhtohepshhrih hnrghthhdvudeffeesghhmrghilhdrtghomhdprhgtphhtthhopehvihhgnhgvshhhvddu sehgmhgrihhlrdgtohhmpdhrtghpthhtohepphhgshhqlhdqhhgrtghkvghrsheslhhish htshdrphhoshhtghhrvghsqhhlrdhorhhgpdhrtghpthhtoheprhhosgesgiiiihhllhgr rdhnvght X-ME-Proxy: Feedback-ID: ia2694551:Fastmail Received: by mail.messagingengine.com (Postfix) with ESMTPA; Mon, 6 Apr 2026 05:38:22 -0400 (EDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=alvh.no-ip.org; s=schmee; t=1775468300; bh=vfBRpnis8x1q6ZWG3e2Jhque3sfDzyrOE5F+Ynrz9/g=; h=Date:From:To:Cc:Subject:In-Reply-To:From; b=fBRlv+CdeRw2O3MwxkSpM3nz/ObcE0wL3xmWDn5kNyN0ddKZM0FQiZLlcZLaTszFd stpFke/F9pIhOdED0T2A1UUBGC/vt1xTqrakXpqzdN8KFCcAJVOj97kD46kRCAJOyx P7rR0iDcad5mEcljHddg7aUZnzARbt9K79sgkw6tCLC+39ZPLqpfep3AIdzwodfmp+ ZpjZlXAW44xxemC/zsVkaIL+SiBCmV8PXmIclqDBJ74TBChVAFIpP/zZWjZSCyqxfd 2tKYJg8j+gONxt70YVZpCGqQThCzP9VtCpzwdmuuw5BGopJN9BmKCrjqvJp8OS5GmB PiiQZox3npDIg== Received: by schmee.kurilemu.internal (Postfix, from userid 1000) id 818BF7C; Mon, 06 Apr 2026 11:38:20 +0200 (CEST) Date: Mon, 6 Apr 2026 11:38:20 +0200 From: Alvaro Herrera To: vignesh C Cc: Antonin Houska , Srinath Reddy Sadipiralla , Amit Kapila , Mihail Nikalayeu , Matthias van de Meent , Pg Hackers , Robert Treat Subject: Re: Adding REPACK [concurrently] Message-ID: <202604060918.qw5ms7cbr2hz@alvherre.pgsql> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: List-Id: List-Help: List-Subscribe: List-Post: List-Owner: List-Archive: Archived-At: Precedence: bulk On 2026-Apr-06, vignesh C wrote: > On Mon, 6 Apr 2026 at 02:12, Alvaro Herrera wrote: > Few comments: Thanks for reviewing this patch! > 1) Can we add a comment why we should error out here, as repack > concurrently requires this whereas repack does not require this check. > Even if it is required for decoding can't it be handled by replica > identity full: > + /* > + * If the identity index is not set due to replica identity being, PK > + * might exist. > + */ > + ident_idx = RelationGetReplicaIndex(rel); > + if (!OidIsValid(ident_idx) && OidIsValid(rel->rd_pkindex)) > + ident_idx = rel->rd_pkindex; > + if (!OidIsValid(ident_idx)) > + ereport(ERROR, > + > errcode(ERRCODE_OBJECT_NOT_IN_PREREQUISITE_STATE), > + errmsg("cannot process relation \"%s\"", > + RelationGetRelationName(rel)), > + errhint("Relation \"%s\" has no > identity index.", > + RelationGetRelationName(rel))); Ah, I was just rewriting that comment moments ago. I think we could make it work with replica identity full in theory, but I'm guessing it would be useless. You really need an index that lets you locate the affected tuples; otherwise the replay would take forever. If the table is big, that would make the whole thing unworkable. If the table isn't big, then you can probably just use straight repack without too much disruption. /* * Obtain the replica identity index -- either one that has been set * explicitly, or the primary key. If none of these cases apply, the * table cannot be repacked concurrently. It might be possible to have * repack work with a FULL replica identity; however that requires more * work and is not implemented yet. */ Now, it's possible to have a non-unique index on some columns (not good enough to be replica identity) which gives you a list of candidate tuples, and then the implementation chooses one based on the other columns which are present in the FULL replica identity. (This seems a bit dangerous, because there might be multiple matching tuples; and how do you choose?) Now let's further suppose you can narrow down to a single tuple; in that case, using FULL would work. However, as I said, this requires more implementation effort. We could entertain a patch for this during the pg20 cycle, though I'm doubtful that it would really be worth your while. > 2) Do you think it will be good to add a test to simulate a case where > one of the swap_replation_files is successful and a failure after > that. We can verify that the oid should still point to old oids: Hmm, it's not clear to me in which cases this can happen. Are you thinking that the first swap_replation_files call dies because of out-of-memory? Note that the really weird cases, like pg_class or mapped relations, are directly rejected. So we don't get into the branch with !RelFileNumberIsValid, and so on. I mean -- I'm not opposed to adding a test case for it. But I suspect it's going to be somewhat annoying to write. > 3) I'm not sure if this change should be part of this patch: > diff --git a/src/backend/storage/lmgr/generate-lwlocknames.pl > b/src/backend/storage/lmgr/generate-lwlocknames.pl > index b49007167b0..2e7f1054e62 100644 > --- a/src/backend/storage/lmgr/generate-lwlocknames.pl > +++ b/src/backend/storage/lmgr/generate-lwlocknames.pl > @@ -162,7 +162,7 @@ while (<$lwlocklist>) > > die > "$wait_event_lwlocks[$lwlock_count] defined in wait_event_names.txt but " > - . " missing from lwlocklist.h" > + . "missing from lwlocklist.h" > if $lwlock_count < scalar @wait_event_lwlocks; Yeah, will remove. > 4) Can we add an example for concurrently in documentation > 5) Typos Sure. > 6) This includes are not required in repack.c, for me it could compile > without it: > +#include "access/detoast.h" > +#include "access/xloginsert.h" > +#include "catalog/pg_control.h" > 7) Can you check if the copyright year mentioned for the new files are > correct, as different files mention different years like: I'll look into these, thanks for pointing it out. -- Álvaro Herrera 48°01'N 7°57'E — https://www.EnterpriseDB.com/ "Linux transformó mi computadora, de una `máquina para hacer cosas', en un aparato realmente entretenido, sobre el cual cada día aprendo algo nuevo" (Jaime Salinas)