On Sat, Jul 19, 2025 at 10:32 AM Amit Kapila <amit.kapila16@gmail.com> wrote:
>
> On Sat, Jul 19, 2025 at 3:01 AM Masahiko Sawada <sawada.mshk@gmail.com> wrote:
> >
> > On Fri, Jul 18, 2025 at 5:03 AM Zhijie Hou (Fujitsu)
> > <houzj.fnst@fujitsu.com> wrote:
> > >
> >
> > Here are some review comments and questions:
> >
> >
> > ---
> > + if (inCommitOnly &&
> > + (proc->delayChkptFlags & DELAY_CHKPT_IN_COMMIT) == 0)
> > + continue;
> > +
> >
> > I've not verified yet but is it possible that we exclude XIDs of
> > processes who are running on other databases?
> >
>
> I can't see how, even the comments atop function says: " We look at
> all databases, though there is no need to include WALSender since this
> has no effect on hot standby conflicts." which indicate that it
> shouldn't exlude XIDs of procs who are running on other databases.
>
I think I misunderstood your question. You were asking if possible, we
should exclude XIDs of processes running on other databases in the
above check as for our purpose, we don't need those. If so, I agree
with you, we don't need XIDs of other databases as logical WALSender
will anyway won't process transactions in other databases, so we can
exclude those. The function GetOldestActiveTransactionId() is called
from two places in patch get_candidate_xid() and
ProcessStandbyPSRequestMessage(). We don't need to care for XIDs in
other databases at both places but care for
Commit_Critical_Section_Phase when called from
ProcessStandbyPSRequestMessage(). So, we probably need two parameters
to distinguish those cases.
--
With Regards,
Amit Kapila.