| From: | wenhui qiu <qiuwenhuifx(at)gmail(dot)com> |
|---|---|
| To: | Shinya Kato <shinya11(dot)kato(at)gmail(dot)com> |
| Cc: | PostgreSQL Hackers <pgsql-hackers(at)lists(dot)postgresql(dot)org> |
| Subject: | Re: Report oldest xmin source when autovacuum cannot remove tuples |
| Date: | 2025-11-11 10:40:04 |
| Message-ID: | CAGjGUAL-qZ6Na-cH4RY5raF4NwuF47ZVNyP0uMYQcks3w5b7Dw@mail.gmail.com |
| Views: | Whole Thread | Raw Message | Download mbox | Resend email |
| Thread: | |
| Lists: | pgsql-hackers |
Hi
Thank you for your response , In this context, that session state is idle
in transaction .If we could further distinguish between active sessions
that are still running and idle sessions, that would be clearer.
Thanks
On Tue, Nov 4, 2025 at 11:59 PM Fujii Masao <masao(dot)fujii(at)gmail(dot)com> wrote:
> On Fri, Oct 31, 2025 at 3:32 PM Shinya Kato <shinya11(dot)kato(at)gmail(dot)com>
> wrote:
> >
> > Hi hackers,
> >
> > I am proposing to add the reason for the oldest xmin to VACUUM logs.
> > This feature would be useful for identifying why dead tuples cannot be
> > removed, thereby helping to diagnose and prevent table bloat.
>
> +1
>
> I like this idea. Thanks for working on this!
>
>
> > This PoC patch addresses this problem. The implementation now outputs
> > the reason for the oldest xmin and, where applicable, the backend PID.
> > This information was originally discarded when calculating the oldest
> > xmin horizon, and the computation required to retrieve these reasons
> > is considered reasonable.
> >
> > The patch is attached. What do you think?
>
> According to cfbot, the 010_autovacuum_oldest_xmin_reason regression test
> passes on some platforms but fails on others (see [1]), so it doesn't
> appear stable.
>
>
> When I set up a primary and standby with hot_standby_feedback enabled,
> then created an old prepared transaction expected to prevent dead tuples
> from being vacuumed, VACUUM VERBOSE reported "hot standby feedback"
> instead of "prepared transaction" as the oldest xmin source. This isn't a
> bug
> since both xmins are the same in this case. But it may be confusing?
> Would it be better to report "prepared transaction" in such cases?
>
>
> + case OLDESTXMIN_SOURCE_ACTIVE_TRANSACTION:
> + msgfmt = include_pid ?
> + _("oldest xmin source: active transaction (pid=%d)\n") :
> + _("oldest xmin source: active transaction\n");
> + break;
> + case OLDESTXMIN_SOURCE_HOT_STANDBY_FEEDBACK:
> + msgfmt = include_pid ?
> + _("oldest xmin source: hot standby feedback (pid=%d)\n") :
> + _("oldest xmin source: hot standby feedback\n");
>
> In these two cases, the PID should always be non-zero, so the message
> formats without (pid=%d) might not be necessary.
>
>
> + /* Identify what forced each of the horizons above. */
> + OldestXminInfo shared_oldest_nonremovable_info;
> + OldestXminInfo catalog_oldest_nonremovable_info;
> + OldestXminInfo data_oldest_nonremovable_info;
> + OldestXminInfo temp_oldest_nonremovable_info;
>
> It might be good to add a comment explaining why we track
> sources only for these four oldest xmins, and not for others
> like oldest_considered_running.
>
>
> + TransactionId old;
> + TransactionId new_horizon;
> +
> + if (!TransactionIdIsValid(candidate))
> + return;
>
> The TransactionIdIsValid(candidate) check may be redundant,
> since TransactionIdOlder(old, candidate) already performs
> the same validation.
>
>
> - switch (GlobalVisHorizonKindForRel(rel))
> + kind = GlobalVisHorizonKindForRel(rel);
> + switch (kind)
>
> This change doesn't seem necessary.
>
> Regards,
>
> [1] https://cirrus-ci.com/task/6063548834512896
>
> --
> Fujii Masao
>
>
>
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Amit Kapila | 2025-11-11 11:08:13 | Re: HASH INDEX builds seems confused |
| Previous Message | Amit Kapila | 2025-11-11 10:33:46 | Re: POC: enable logical decoding when wal_level = 'replica' without a server restart |