BUG #18876: HINT messages for mxid wrap-around say "drop stale slots", but that may not be appropriate - Mailing list pgsql-bugs

From PG Bug reporting form
Subject BUG #18876: HINT messages for mxid wrap-around say "drop stale slots", but that may not be appropriate
Date
Msg-id 18876-0d0b53bad5a1f4c1@postgresql.org
Whole thread Raw
List pgsql-bugs
The following bug has been logged on the website:

Bug reference:      18876
Logged by:          TAKATSUKA Haruka
Email address:      harukat@sraoss.co.jp
PostgreSQL version: 17.4
Operating system:   any
Description:

In src/backend/access/transam/multixact.c, there are the following hint
messages:

  "Execute a database-wide VACUUM in that database.\n"
  "You might also need to commit or roll back old prepared transactions, or
drop stale replication slots."

  "To avoid MultiXactId assignment failures, execute a database-wide VACUUM
in that database.\n"
  "You might also need to commit or roll back old prepared transactions, or
drop stale replication slots."

I think that their "drop stale replication slots" is not appropriate. 

Because NewRelminMxid is determined by GetOldestMultiXactId() and its
comment says:
   * Return the oldest MultiXactId that's still possibly still seen as live
by  
   * any running transaction.  Older ones might still exist on disk, but
they no
   * longer have any running member transaction.

Thus, the presence of an old mxid in a tuple pending removal by a slot is
not considered to affect it.

In addition, as far as I have tested, leaving the old inactive replication
slot does not cause mxid_age(relminmxid) not to decrease after VACUUM.

Thanks,


pgsql-bugs by date:

Previous
From: Tom Lane
Date:
Subject: Re: BUG #18875: COPY BINARY tsvector FROM file leads to misaligned memory access
Next
From: Heikki Linnakangas
Date:
Subject: Re: BUG #18396: Assert in gistFindCorrectParent() fails on inserting large tuples into gist index