From: | Andres Freund <andres(at)anarazel(dot)de> |
---|---|
To: | "Nasby, Jim" <nasbyj(at)amazon(dot)com> |
Cc: | Sergei Kornilov <sk(at)zsrv(dot)org>, Robert Haas <robertmhaas(at)gmail(dot)com>, Alvaro Herrera <alvherre(at)2ndquadrant(dot)com>, Michael Paquier <michael(at)paquier(dot)xyz>, PostgreSQL Hackers <pgsql-hackers(at)lists(dot)postgresql(dot)org> |
Subject: | Re: pgsql: Improve autovacuum logging for aggressive and anti-wraparound ru |
Date: | 2018-09-24 18:29:34 |
Message-ID: | 20180924182934.rpl3lkoisy5o2tx4@alap3.anarazel.de |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-committers pgsql-hackers |
On 2018-09-24 18:25:46 +0000, Nasby, Jim wrote:
>
> > On Sep 21, 2018, at 12:43 PM, Andres Freund <andres(at)anarazel(dot)de> wrote:
> >
> >> But as far i can see it is possible have aggressive non-wraparound vacuum. One important difference - regular and aggressive regular can be canceled by backend,.wraparound autovacuum can not. (by checking PROC_VACUUM_FOR_WRAPAROUND in src/backend/storage/lmgr/proc.c )
> >
> > Yes, without checking the code, they should be different. Aggressive is
> > controlled by vacuum_freeze_table_age whereas anti-wrap is controlled by
> > autovacuum_freeze_max_age (but also implies aggressive).
>
> Right, except that by the time you get into the vacuum code itself nothing should really care about that difference. AFAICT, the only thing is_wraparound is being used for is to set MyPgXact->vacuumFlags |= PROC_VACUUM_FOR_WRAPAROUND, which prevents the deadlock detector from killing an autovac process that’s trying to prevent a wraparound. I think it’d be clearer to remove is_wraparound and move the check from vacuum_rel() into lazy_vacuum_rel() (which is where the limits for HeapTupleSatisfiesVacuum get determined). Something like the attached.
I'm very doubtful this is an improvement. Especially with the upcoming
pluggable storage work making vacuumlazy.c heap specific, while vacuum.c
stays generic. The concept of something like
PROC_VACUUM_FOR_WRAPAROUND, should imo not be pushed down that much
(even if criteria for it might).
Greetings,
Andres Freund
From | Date | Subject | |
---|---|---|---|
Next Message | Tom Lane | 2018-09-24 18:41:10 | pgsql: Use ppoll(2), if available, to wait for input in pgbench. |
Previous Message | Nasby, Jim | 2018-09-24 18:25:46 | Re: pgsql: Improve autovacuum logging for aggressive and anti-wraparound ru |
From | Date | Subject | |
---|---|---|---|
Next Message | Lukas Fittl | 2018-09-24 18:34:38 | auto_explain: Include JIT output if applicable |
Previous Message | Nasby, Jim | 2018-09-24 18:25:46 | Re: pgsql: Improve autovacuum logging for aggressive and anti-wraparound ru |