From ae74b550f99e0ff6686897fa9a1b6f0308778909 Mon Sep 17 00:00:00 2001 From: Gui Iribarren Date: Mon, 9 Sep 2024 18:16:12 +0200 Subject: [PATCH] indexer: hotfix ReindexBlocks * defer call, to avoid races with startDB init stuff * add idx.blockTx.Commit every 10000 blocks and after finishing * add some progress log every 10000 blocks --- vochain/indexer/indexer.go | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) diff --git a/vochain/indexer/indexer.go b/vochain/indexer/indexer.go index 4d6710560..b99f13832 100644 --- a/vochain/indexer/indexer.go +++ b/vochain/indexer/indexer.go @@ -176,7 +176,7 @@ func (idx *Indexer) startDB() error { if gooseMigrationsPending(idx.readWriteDB, "migrations") { log.Info("indexer db needs migration, scheduling a reindex after sync") - go idx.ReindexBlocks(false) + defer func() { go idx.ReindexBlocks(false) }() } if err := goose.Up(idx.readWriteDB, "migrations"); err != nil { @@ -459,6 +459,15 @@ func (idx *Indexer) ReindexBlocks(inTest bool) { // Blocks func() { idxBlock, err := idx.readOnlyQuery.GetBlockByHeight(context.TODO(), b.Height) + if height%10000 == 1 { + log.Infof("reindexing height %d, updating values (%s, %x, %x, %x) on current row %+v", + height, b.ChainID, b.Hash(), b.ProposerAddress, b.LastBlockID.Hash, idxBlock) + if err := idx.blockTx.Commit(); err != nil { + log.Errorw(err, "could not commit tx") + } + idx.blockTx = nil + queries = idx.blockTxQueries() + } if err == nil && idxBlock.Time != b.Time { log.Errorf("while reindexing blocks, block %d timestamp in db (%s) differs from blockstore (%s), leaving untouched", height, idxBlock.Time, b.Time) return @@ -497,6 +506,11 @@ func (idx *Indexer) ReindexBlocks(inTest bool) { } } + if err := idx.blockTx.Commit(); err != nil { + log.Errorw(err, "could not commit tx") + } + idx.blockTx = nil + log.Infow("finished reindexing", "blockStoreBase", idx.App.Node.BlockStore().Base(), "blockStoreHeight", idx.App.Node.BlockStore().Height(),