| From: | Peter Geoghegan <pg(at)bowt(dot)ie> | 
|---|---|
| To: | Masahiko Sawada <sawada(dot)mshk(at)gmail(dot)com> | 
| Cc: | PostgreSQL-development <pgsql-hackers(at)postgresql(dot)org> | 
| Subject: | Re: New IndexAM API controlling index vacuum strategies | 
| Date: | 2021-03-02 05:34:40 | 
| Message-ID: | CAH2-WzmSGN+n7f-H38YheTuN+o-v1R6jLhceDPkbrM-GCf0NjA@mail.gmail.com | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-hackers | 
On Mon, Mar 1, 2021 at 7:00 PM Peter Geoghegan <pg(at)bowt(dot)ie> wrote:
> I think that you're right. However, in practice it isn't harmful
> because has_dead_tuples is only used when "all_visible = true", and
> only to detect corruption (which should never happen). I think that it
> should be fixed as part of this work, though.
Currently the first callsite that calls the new
lazy_vacuum_table_and_indexes() function in the patch
("skip_index_vacuum.patch") skips index vacuuming in exactly the same
way as the second and final lazy_vacuum_table_and_indexes() call site.
Don't we need to account for maintenance_work_mem in some way?
lazy_vacuum_table_and_indexes() should probably not skip index
vacuuming when we're close to exceeding the space allocated for the
LVDeadTuples array. Maybe we should not skip when
vacrelstats->dead_tuples->num_tuples is greater than 50% of
dead_tuples->max_tuples? Of course, this would only need to be
considered when lazy_vacuum_table_and_indexes() is only called once
for the entire VACUUM operation (otherwise we have far too little
maintenance_work_mem/dead_tuples->max_tuples anyway).
-- 
Peter Geoghegan
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Andrey Borodin | 2021-03-02 05:50:39 | Re: libpq compression | 
| Previous Message | Tom Lane | 2021-03-02 05:31:46 | Re: Re: [PATCH] regexp_positions ( string text, pattern text, flags text ) → setof int4range[] |