From 5c5bf6313cf14137b22c3b4426f8ec74d54519c1 Mon Sep 17 00:00:00 2001 From: welkin22 <136572398+welkin22@users.noreply.github.com> Date: Tue, 30 Jan 2024 16:06:10 +0800 Subject: [PATCH] fix(op-node): pre-fetching handle L1 reOrg round 2 (#117) Co-authored-by: Welkin --- op-node/sources/l1_client.go | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) diff --git a/op-node/sources/l1_client.go b/op-node/sources/l1_client.go index 108704bcc142..4c5674725a89 100644 --- a/op-node/sources/l1_client.go +++ b/op-node/sources/l1_client.go @@ -141,7 +141,7 @@ func (s *L1Client) GoOrUpdatePreFetchReceipts(ctx context.Context, l1Start uint6 s.log.Info("pre-fetching receipts start", "startBlock", l1Start) go func() { var currentL1Block uint64 - var parentHash *common.Hash + var parentHash common.Hash for { select { case <-s.done: @@ -150,7 +150,7 @@ func (s *L1Client) GoOrUpdatePreFetchReceipts(ctx context.Context, l1Start uint6 case currentL1Block = <-s.preFetchReceiptsStartBlockChan: s.log.Debug("pre-fetching receipts currentL1Block changed", "block", currentL1Block) s.receiptsCache.RemoveAll() - parentHash = nil + parentHash = common.Hash{} default: blockRef, err := s.L1BlockRefByLabel(ctx, eth.Unsafe) if err != nil { @@ -194,13 +194,15 @@ func (s *L1Client) GoOrUpdatePreFetchReceipts(ctx context.Context, l1Start uint6 continue } if ok && pair.blockHash == blockInfo.Hash { + blockInfoChan <- blockInfo return } isSuccess, err := s.PreFetchReceipts(ctx, blockInfo.Hash) if err != nil { s.log.Warn("failed to pre-fetch receipts", "err", err) - return + time.Sleep(1 * time.Second) + continue } if !isSuccess { s.log.Debug("pre fetch receipts fail without error,need retry", "blockHash", blockInfo.Hash, "blockNumber", blockNumber) @@ -233,13 +235,13 @@ func (s *L1Client) GoOrUpdatePreFetchReceipts(ctx context.Context, l1Start uint6 } s.log.Debug("pre-fetching receipts hash", "latestBlockHash", latestBlockHash, "latestBlockNumber", latestBlockNumber, "oldestBlockNumber", oldestFetchBlockNumber, "oldestBlockParentHash", oldestBlockParentHash) - if parentHash != nil && oldestBlockParentHash != (common.Hash{}) && oldestBlockParentHash != *parentHash && currentL1Block >= sequencerConfDepth+uint64(taskCount) { + if parentHash != (common.Hash{}) && oldestBlockParentHash != (common.Hash{}) && oldestBlockParentHash != parentHash && currentL1Block >= sequencerConfDepth+uint64(taskCount) { currentL1Block = currentL1Block - sequencerConfDepth - uint64(taskCount) - s.log.Warn("pre-fetching receipts found l1 reOrg, return to an earlier block height for re-prefetching", "recordParentHash", *parentHash, "unsafeParentHash", oldestBlockParentHash, "number", oldestFetchBlockNumber, "backToNumber", currentL1Block) - parentHash = nil + s.log.Warn("pre-fetching receipts found l1 reOrg, return to an earlier block height for re-prefetching", "recordParentHash", parentHash, "unsafeParentHash", oldestBlockParentHash, "number", oldestFetchBlockNumber, "backToNumber", currentL1Block) + parentHash = common.Hash{} continue } - parentHash = &latestBlockHash + parentHash = latestBlockHash } } }()