From: | Robert Haas <robertmhaas(at)gmail(dot)com> |
---|---|
To: | Masahiko Sawada <sawada(dot)mshk(at)gmail(dot)com> |
Cc: | PostgreSQL-development <pgsql-hackers(at)postgresql(dot)org> |
Subject: | Re: [HACKERS] ginInsertCleanup called from vacuum could still miss tuples to be deleted |
Date: | 2017-11-16 02:24:49 |
Message-ID: | CA+Tgmob_7nw_DzS3M-v0VStVdyJGE7bF13AxyEf4NEhEWDmnaA@mail.gmail.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-hackers |
On Mon, Nov 13, 2017 at 3:25 AM, Masahiko Sawada <sawada(dot)mshk(at)gmail(dot)com> wrote:
> In ginInsertCleanup(), we lock the GIN meta page by LockPage and could
> wait for the concurrent cleaning up process if stats == NULL. And the
> source code comment says that this happen is when ginINsertCleanup is
> called by [auto]vacuum/analyze or gin_clean_pending_list(). I agree
> with this behavior. However, looking at the callers the stats is NULL
> only either if pending list exceeds to threshold during insertions or
> if only analyzing is performed by an autovacum worker or ANALYZE
> command. So I think we should inVacuum = (stats != NULL) instead.
Argh. Yeah, that looks wrong.
Instead of relying on this indirect method, how about passing an
explicit inVacuum argument to that function? And while we're at it,
how about renaming inVacuum to forceCleanup?
--
Robert Haas
EnterpriseDB: http://www.enterprisedb.com
The Enterprise PostgreSQL Company
From | Date | Subject | |
---|---|---|---|
Next Message | Amit Kapila | 2017-11-16 02:34:36 | Re: [HACKERS] [POC] Faster processing at Gather node |
Previous Message | Amit Langote | 2017-11-16 02:21:05 | Re: [HACKERS] moving some partitioning code to executor |