public inbox for [email protected]
help / color / mirror / Atom feedFrom: Mihail Nikalayeu <[email protected]>
To: Antonin Houska <[email protected]>
Cc: Alvaro Herrera <[email protected]>
Cc: Pg Hackers <[email protected]>
Cc: Robert Treat <[email protected]>
Subject: Re: Adding REPACK [concurrently]
Date: Sat, 10 Jan 2026 20:37:06 +0300
Message-ID: <CADzfLwU-OmxW3t3AoQo9=K7uq4G1yZ-txcetzW3jbcVxV_pJew@mail.gmail.com> (raw)
In-Reply-To: <141054.1767891540@localhost>
References: <[email protected]>
<11247.1767609087@localhost>
<11558.1767609632@localhost>
<141054.1767891540@localhost>
Hello, Antonin!
On Thu, Jan 8, 2026 at 7:59 PM Antonin Houska <[email protected]> wrote:
> v29 tries to fix the problem.
Some comments for 0001-0004.
------ 0001 -----
> src/bin/scripts/t/103_repackdb.pl:1:
> # Copyright (c) 2021-2025
Update year for 2026.
> * FIXME: this is missing a way to specify the index to use to repack one
> * table, or whether to pass a WITH INDEX clause when multiple tables are
> * used. Something like --index[=indexname]. Adding that bleeds into
> * vacuuming.c as well.
Comments look stale.
> return "???";
I think it is better to add Assert(false); before (done that way in a
few places).
> command <link linkend="sql-repack"><command>REPACK</command></link> There
need .
> “An utility”
Should be “A utility”
> else if (pg_strcasecmp(cmd, "CLUSTER") == 0)
> cmdtype = PROGRESS_COMMAND_CLUSTER;
Should we set PROGRESS_COMMAND_REPACK here? Because cluster is not
used anywhere. Probably we may even delete PROGRESS_COMMAND_CLUSTER.
> CLUOPT_RECHECK_ISCLUSTERED
It is not set anymore... Probably something is wrong here or we need
to just remove that constant and check for it.
------ 0002 -----
> rebuild_relation(Relation OldHeap, Relation index, bool verbose)
It removes unused cmd parameter, but I think it is better to not add
it in the previous commit.
------ 0003 -----
> int newxcnt = 0;
I think it is better to use uint32 for consistency here.
Also, I think it is worth adding Assert(snapshot->snapshot_type ==
SNAPSHOT_HISTORIC_MVCC)
------ 0004 -----
> /* Is REPACK (CONCURRENTLY) being run by this backend? */
> if (am_decoding_for_repack())
We should check change_useless_for_repack here - to avoid looking and
TRUNCATE of unrelated tables.
> /* For the same reason, unlock TOAST relation. */
> if (OldHeap->rd_rel->reltoastrelid)
> LockRelationOid(OldHeap->rd_rel->reltoastrelid, AccessExclusiveLock);
Hm, we are locking here instead of unlocking ;)
> (errhint("Relation \"%s\" has no identity index.",
> RelationGetRelationName(rel)))));
One level of braces may be removed.
> * to decode on behalf of REPACK (CONCURRENT)?
CONCURRENTLY
> * If recheck is required, it must have been preformed on the source
"performed"
> * On exit,'*scan_p' contains the scan descriptor used. The caller must close
> * it when he no longer needs the tuple returned.
There is no scan_p argument here.
> * Copyright (c) 2012-2025, PostgreSQL Global Development Group
2026
> newtuple = change->data.tp.newtuple != NULL ?
> change->data.tp.newtuple : NULL;
> oldtuple = change->data.tp.oldtuple != NULL ?
> change->data.tp.oldtuple : NULL;
> newtuple = change->data.tp.newtuple != NULL ?
> change->data.tp.newtuple : NULL;
Hm, should it be just x = y ?
> apply_concurrent_insert
Double newline at function start.
> heap2_decode
Should we check for change_useless_for_repack here also? (for multi
insert, for example).
Best regards,
Mikhail.
view thread (31+ messages) latest in thread
reply
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Reply to all the recipients using the --to and --cc options:
reply via email
To: [email protected]
Cc: [email protected], [email protected], [email protected], [email protected], [email protected]
Subject: Re: Adding REPACK [concurrently]
In-Reply-To: <CADzfLwU-OmxW3t3AoQo9=K7uq4G1yZ-txcetzW3jbcVxV_pJew@mail.gmail.com>
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
This inbox is served by agora; see mirroring instructions
for how to clone and mirror all data and code used for this inbox