Commit dc943ad9 authored by Teodor Sigaev's avatar Teodor Sigaev

Allow autoanalyze to add pages deleted from pending list to FSM

Commit e9568083 introduces adding pages
to FSM for ordinary insert, but autoanalyze was able just cleanup
pending list without adding to FSM.

Also fix double call of IndexFreeSpaceMapVacuum() during ginvacuumcleanup()

Report from Fujii Masao
Patch by me
Review by Jeff Janes
parent 262e56bc
...@@ -434,7 +434,7 @@ ginHeapTupleFastInsert(GinState *ginstate, GinTupleCollector *collector) ...@@ -434,7 +434,7 @@ ginHeapTupleFastInsert(GinState *ginstate, GinTupleCollector *collector)
END_CRIT_SECTION(); END_CRIT_SECTION();
if (needCleanup) if (needCleanup)
ginInsertCleanup(ginstate, false, NULL); ginInsertCleanup(ginstate, false, true, NULL);
} }
/* /*
...@@ -505,7 +505,7 @@ ginHeapTupleFastCollect(GinState *ginstate, ...@@ -505,7 +505,7 @@ ginHeapTupleFastCollect(GinState *ginstate,
*/ */
static bool static bool
shiftList(Relation index, Buffer metabuffer, BlockNumber newHead, shiftList(Relation index, Buffer metabuffer, BlockNumber newHead,
IndexBulkDeleteResult *stats) bool fill_fsm, IndexBulkDeleteResult *stats)
{ {
Page metapage; Page metapage;
GinMetaPageData *metadata; GinMetaPageData *metadata;
...@@ -613,7 +613,7 @@ shiftList(Relation index, Buffer metabuffer, BlockNumber newHead, ...@@ -613,7 +613,7 @@ shiftList(Relation index, Buffer metabuffer, BlockNumber newHead,
END_CRIT_SECTION(); END_CRIT_SECTION();
for (i = 0; i < data.ndeleted; i++) for (i = 0; fill_fsm && i < data.ndeleted; i++)
RecordFreeIndexPage(index, freespace[i]); RecordFreeIndexPage(index, freespace[i]);
} while (blknoToDelete != newHead); } while (blknoToDelete != newHead);
...@@ -732,13 +732,19 @@ processPendingPage(BuildAccumulator *accum, KeyArray *ka, ...@@ -732,13 +732,19 @@ processPendingPage(BuildAccumulator *accum, KeyArray *ka,
* action of removing a page from the pending list really needs exclusive * action of removing a page from the pending list really needs exclusive
* lock. * lock.
* *
* vac_delay indicates that ginInsertCleanup is called from vacuum process, * vac_delay indicates that ginInsertCleanup should call
* so call vacuum_delay_point() periodically. * vacuum_delay_point() periodically.
*
* fill_fsm indicates that ginInsertCleanup should add deleted pages
* to FSM otherwise caller is responsible to put deleted pages into
* FSM.
*
* If stats isn't null, we count deleted pending pages into the counts. * If stats isn't null, we count deleted pending pages into the counts.
*/ */
void void
ginInsertCleanup(GinState *ginstate, ginInsertCleanup(GinState *ginstate,
bool vac_delay, IndexBulkDeleteResult *stats) bool vac_delay, bool fill_fsm,
IndexBulkDeleteResult *stats)
{ {
Relation index = ginstate->index; Relation index = ginstate->index;
Buffer metabuffer, Buffer metabuffer,
...@@ -899,7 +905,7 @@ ginInsertCleanup(GinState *ginstate, ...@@ -899,7 +905,7 @@ ginInsertCleanup(GinState *ginstate,
* remove read pages from pending list, at this point all * remove read pages from pending list, at this point all
* content of read pages is in regular structure * content of read pages is in regular structure
*/ */
if (shiftList(index, metabuffer, blkno, stats)) if (shiftList(index, metabuffer, blkno, fill_fsm, stats))
{ {
/* another cleanup process is running concurrently */ /* another cleanup process is running concurrently */
LockBuffer(metabuffer, GIN_UNLOCK); LockBuffer(metabuffer, GIN_UNLOCK);
...@@ -948,7 +954,7 @@ ginInsertCleanup(GinState *ginstate, ...@@ -948,7 +954,7 @@ ginInsertCleanup(GinState *ginstate,
* desirable to recycle them immediately to the FreeSpace Map when * desirable to recycle them immediately to the FreeSpace Map when
* ordinary backends clean the list. * ordinary backends clean the list.
*/ */
if (fsm_vac && !vac_delay) if (fsm_vac && fill_fsm)
IndexFreeSpaceMapVacuum(index); IndexFreeSpaceMapVacuum(index);
......
...@@ -544,7 +544,7 @@ ginbulkdelete(PG_FUNCTION_ARGS) ...@@ -544,7 +544,7 @@ ginbulkdelete(PG_FUNCTION_ARGS)
/* Yes, so initialize stats to zeroes */ /* Yes, so initialize stats to zeroes */
stats = (IndexBulkDeleteResult *) palloc0(sizeof(IndexBulkDeleteResult)); stats = (IndexBulkDeleteResult *) palloc0(sizeof(IndexBulkDeleteResult));
/* and cleanup any pending inserts */ /* and cleanup any pending inserts */
ginInsertCleanup(&gvs.ginstate, true, stats); ginInsertCleanup(&gvs.ginstate, true, false, stats);
} }
/* we'll re-count the tuples each time */ /* we'll re-count the tuples each time */
...@@ -659,7 +659,7 @@ ginvacuumcleanup(PG_FUNCTION_ARGS) ...@@ -659,7 +659,7 @@ ginvacuumcleanup(PG_FUNCTION_ARGS)
if (IsAutoVacuumWorkerProcess()) if (IsAutoVacuumWorkerProcess())
{ {
initGinState(&ginstate, index); initGinState(&ginstate, index);
ginInsertCleanup(&ginstate, true, stats); ginInsertCleanup(&ginstate, true, true, stats);
} }
PG_RETURN_POINTER(stats); PG_RETURN_POINTER(stats);
} }
...@@ -672,7 +672,7 @@ ginvacuumcleanup(PG_FUNCTION_ARGS) ...@@ -672,7 +672,7 @@ ginvacuumcleanup(PG_FUNCTION_ARGS)
{ {
stats = (IndexBulkDeleteResult *) palloc0(sizeof(IndexBulkDeleteResult)); stats = (IndexBulkDeleteResult *) palloc0(sizeof(IndexBulkDeleteResult));
initGinState(&ginstate, index); initGinState(&ginstate, index);
ginInsertCleanup(&ginstate, true, stats); ginInsertCleanup(&ginstate, true, false, stats);
} }
memset(&idxStat, 0, sizeof(idxStat)); memset(&idxStat, 0, sizeof(idxStat));
......
...@@ -936,7 +936,7 @@ extern void ginHeapTupleFastCollect(GinState *ginstate, ...@@ -936,7 +936,7 @@ extern void ginHeapTupleFastCollect(GinState *ginstate,
OffsetNumber attnum, Datum value, bool isNull, OffsetNumber attnum, Datum value, bool isNull,
ItemPointer ht_ctid); ItemPointer ht_ctid);
extern void ginInsertCleanup(GinState *ginstate, extern void ginInsertCleanup(GinState *ginstate,
bool vac_delay, IndexBulkDeleteResult *stats); bool vac_delay, bool fill_fsm, IndexBulkDeleteResult *stats);
/* ginpostinglist.c */ /* ginpostinglist.c */
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment