From 676f41f252dc9cd25963f6e45e4901e9f291349f Mon Sep 17 00:00:00 2001 From: colinlyguo Date: Tue, 19 Nov 2024 00:35:25 +0800 Subject: [PATCH 1/5] feat(bundle-proposer): static batch per bundle --- rollup/conf/config.json | 3 +- rollup/internal/config/l2.go | 3 +- .../controller/watcher/bundle_proposer.go | 39 +++++++------------ .../watcher/bundle_proposer_test.go | 28 +++++++------ rollup/tests/rollup_test.go | 6 +-- 5 files changed, 31 insertions(+), 48 deletions(-) diff --git a/rollup/conf/config.json b/rollup/conf/config.json index fa9ba680a..7da497e63 100644 --- a/rollup/conf/config.json +++ b/rollup/conf/config.json @@ -103,8 +103,7 @@ "max_uncompressed_batch_bytes_size": 634880 }, "bundle_proposer_config": { - "max_batch_num_per_bundle": 20, - "bundle_timeout_sec": 36000 + "batch_num_per_bundle": 20 } }, "db_config": { diff --git a/rollup/internal/config/l2.go b/rollup/internal/config/l2.go index 4db24fb73..1b6c8a90e 100644 --- a/rollup/internal/config/l2.go +++ b/rollup/internal/config/l2.go @@ -51,6 +51,5 @@ type BatchProposerConfig struct { // BundleProposerConfig loads bundle_proposer configuration items. type BundleProposerConfig struct { - MaxBatchNumPerBundle uint64 `json:"max_batch_num_per_bundle"` - BundleTimeoutSec uint64 `json:"bundle_timeout_sec"` + BatchNumPerBundle uint64 `json:"batch_num_per_bundle"` } diff --git a/rollup/internal/controller/watcher/bundle_proposer.go b/rollup/internal/controller/watcher/bundle_proposer.go index 686ad580c..4725a785e 100644 --- a/rollup/internal/controller/watcher/bundle_proposer.go +++ b/rollup/internal/controller/watcher/bundle_proposer.go @@ -3,7 +3,6 @@ package watcher import ( "context" "errors" - "time" "github.com/prometheus/client_golang/prometheus" "github.com/prometheus/client_golang/prometheus/promauto" @@ -25,8 +24,7 @@ type BundleProposer struct { batchOrm *orm.Batch bundleOrm *orm.Bundle - maxBatchNumPerBundle uint64 - bundleTimeoutSec uint64 + batchNumPerBundle uint64 chainCfg *params.ChainConfig @@ -41,17 +39,16 @@ type BundleProposer struct { // NewBundleProposer creates a new BundleProposer instance. func NewBundleProposer(ctx context.Context, cfg *config.BundleProposerConfig, chainCfg *params.ChainConfig, db *gorm.DB, reg prometheus.Registerer) *BundleProposer { - log.Info("new bundle proposer", "bundleBatchesNum", cfg.MaxBatchNumPerBundle, "bundleTimeoutSec", cfg.BundleTimeoutSec) + log.Info("new bundle proposer", "bundleBatchesNum", cfg.BatchNumPerBundle) p := &BundleProposer{ - ctx: ctx, - db: db, - chunkOrm: orm.NewChunk(db), - batchOrm: orm.NewBatch(db), - bundleOrm: orm.NewBundle(db), - maxBatchNumPerBundle: cfg.MaxBatchNumPerBundle, - bundleTimeoutSec: cfg.BundleTimeoutSec, - chainCfg: chainCfg, + ctx: ctx, + db: db, + chunkOrm: orm.NewChunk(db), + batchOrm: orm.NewBatch(db), + bundleOrm: orm.NewBundle(db), + batchNumPerBundle: cfg.BatchNumPerBundle, + chainCfg: chainCfg, bundleProposerCircleTotal: promauto.With(reg).NewCounter(prometheus.CounterOpts{ Name: "rollup_propose_bundle_circle_total", @@ -129,8 +126,8 @@ func (p *BundleProposer) proposeBundle() error { } // select at most maxBlocksThisChunk blocks - maxBatchesThisBundle := p.maxBatchNumPerBundle - batches, err := p.batchOrm.GetBatchesGEIndexGECodecVersion(p.ctx, firstUnbundledBatchIndex, encoding.CodecV3, int(maxBatchesThisBundle)) + batchesThisBundle := p.batchNumPerBundle + batches, err := p.batchOrm.GetBatchesGEIndexGECodecVersion(p.ctx, firstUnbundledBatchIndex, encoding.CodecV3, int(batchesThisBundle)) if err != nil { return err } @@ -161,21 +158,13 @@ func (p *BundleProposer) proposeBundle() error { currentHardfork := encoding.GetHardforkName(p.chainCfg, chunk.StartBlockNumber, chunk.StartBlockTime) if currentHardfork != hardforkName { batches = batches[:i] - maxBatchesThisBundle = uint64(i) // update maxBlocksThisChunk to trigger chunking, because these blocks are the last blocks before the hardfork + batchesThisBundle = uint64(i) // update maxBlocksThisChunk to trigger chunking, because these blocks are the last blocks before the hardfork break } } - if uint64(len(batches)) == maxBatchesThisBundle { - log.Info("reached maximum number of batches per bundle", "batch count", len(batches), "start batch index", batches[0].Index, "end batch index", batches[len(batches)-1].Index) - p.bundleFirstBlockTimeoutReached.Inc() - p.bundleBatchesNum.Set(float64(len(batches))) - return p.updateDBBundleInfo(batches, codecVersion) - } - - currentTimeSec := uint64(time.Now().Unix()) - if firstChunk.StartBlockTime+p.bundleTimeoutSec < currentTimeSec { - log.Info("first block timeout", "batch count", len(batches), "start block number", firstChunk.StartBlockNumber, "start block timestamp", firstChunk.StartBlockTime, "current time", currentTimeSec) + if uint64(len(batches)) == batchesThisBundle { + log.Info("reached number of batches per bundle", "batch count", len(batches), "start batch index", batches[0].Index, "end batch index", batches[len(batches)-1].Index) p.bundleFirstBlockTimeoutReached.Inc() p.bundleBatchesNum.Set(float64(len(batches))) return p.updateDBBundleInfo(batches, codecVersion) diff --git a/rollup/internal/controller/watcher/bundle_proposer_test.go b/rollup/internal/controller/watcher/bundle_proposer_test.go index c866f5f32..22703e077 100644 --- a/rollup/internal/controller/watcher/bundle_proposer_test.go +++ b/rollup/internal/controller/watcher/bundle_proposer_test.go @@ -23,33 +23,33 @@ import ( func testBundleProposerLimits(t *testing.T) { tests := []struct { name string - maxBatchNumPerBundle uint64 + batchNumPerBundle uint64 bundleTimeoutSec uint64 expectedBundlesLen int expectedBatchesInFirstBundle uint64 // only be checked when expectedBundlesLen > 0 }{ { - name: "NoLimitReached", - maxBatchNumPerBundle: math.MaxUint64, - bundleTimeoutSec: math.MaxUint32, - expectedBundlesLen: 0, + name: "NoLimitReached", + batchNumPerBundle: math.MaxUint64, + bundleTimeoutSec: math.MaxUint32, + expectedBundlesLen: 0, }, { name: "Timeout", - maxBatchNumPerBundle: math.MaxUint64, + batchNumPerBundle: math.MaxUint64, bundleTimeoutSec: 0, expectedBundlesLen: 1, expectedBatchesInFirstBundle: 2, }, { - name: "maxBatchNumPerBundleIs0", - maxBatchNumPerBundle: 0, - bundleTimeoutSec: math.MaxUint32, - expectedBundlesLen: 0, + name: "maxBatchNumPerBundleIs0", + batchNumPerBundle: 0, + bundleTimeoutSec: math.MaxUint32, + expectedBundlesLen: 0, }, { name: "maxBatchNumPerBundleIs1", - maxBatchNumPerBundle: 1, + batchNumPerBundle: 1, bundleTimeoutSec: math.MaxUint32, expectedBundlesLen: 1, expectedBatchesInFirstBundle: 1, @@ -115,8 +115,7 @@ func testBundleProposerLimits(t *testing.T) { bap.TryProposeBatch() // batch2 contains chunk2 bup := NewBundleProposer(context.Background(), &config.BundleProposerConfig{ - MaxBatchNumPerBundle: tt.maxBatchNumPerBundle, - BundleTimeoutSec: tt.bundleTimeoutSec, + BatchNumPerBundle: tt.batchNumPerBundle, }, chainConfig, db, nil) bup.TryProposeBundle() @@ -205,8 +204,7 @@ func testBundleProposerRespectHardforks(t *testing.T) { } bup := NewBundleProposer(context.Background(), &config.BundleProposerConfig{ - MaxBatchNumPerBundle: math.MaxUint64, - BundleTimeoutSec: 0, + BatchNumPerBundle: math.MaxUint64, }, chainConfig, db, nil) for i := 0; i < 5; i++ { diff --git a/rollup/tests/rollup_test.go b/rollup/tests/rollup_test.go index ea99b508e..4ccf12ac9 100644 --- a/rollup/tests/rollup_test.go +++ b/rollup/tests/rollup_test.go @@ -113,8 +113,7 @@ func testCommitBatchAndFinalizeBatchOrBundleWithAllCodecVersions(t *testing.T) { }, chainConfig, db, nil) bup := watcher.NewBundleProposer(context.Background(), &config.BundleProposerConfig{ - MaxBatchNumPerBundle: 1000000, - BundleTimeoutSec: 300, + BatchNumPerBundle: 1000000, }, chainConfig, db, nil) l2BlockOrm := orm.NewL2Block(db) @@ -280,8 +279,7 @@ func testCommitBatchAndFinalizeBatchOrBundleCrossingAllTransitions(t *testing.T) }, chainConfig, db, nil) bup := watcher.NewBundleProposer(context.Background(), &config.BundleProposerConfig{ - MaxBatchNumPerBundle: 1000000, - BundleTimeoutSec: 300, + BatchNumPerBundle: 1000000, }, chainConfig, db, nil) cp.TryProposeChunk() From 0b33b812f8208e2482c6901481e4d024767eabda Mon Sep 17 00:00:00 2001 From: colinlyguo Date: Mon, 18 Nov 2024 16:36:37 +0000 Subject: [PATCH 2/5] =?UTF-8?q?chore:=20auto=20version=20bump=E2=80=89[bot?= =?UTF-8?q?]?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- common/version/version.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/common/version/version.go b/common/version/version.go index f84f9b78c..01f8a6df5 100644 --- a/common/version/version.go +++ b/common/version/version.go @@ -5,7 +5,7 @@ import ( "runtime/debug" ) -var tag = "v4.4.75" +var tag = "v4.4.76" var commit = func() string { if info, ok := debug.ReadBuildInfo(); ok { From 8882d4db34f08825c2d1d2095183df3ea6c22155 Mon Sep 17 00:00:00 2001 From: colinlyguo Date: Tue, 19 Nov 2024 02:47:24 +0800 Subject: [PATCH 3/5] fix unit tests --- .../internal/controller/watcher/bundle_proposer.go | 12 +++--------- .../controller/watcher/bundle_proposer_test.go | 10 ++-------- 2 files changed, 5 insertions(+), 17 deletions(-) diff --git a/rollup/internal/controller/watcher/bundle_proposer.go b/rollup/internal/controller/watcher/bundle_proposer.go index 4725a785e..4c25a4902 100644 --- a/rollup/internal/controller/watcher/bundle_proposer.go +++ b/rollup/internal/controller/watcher/bundle_proposer.go @@ -33,7 +33,6 @@ type BundleProposer struct { proposeBundleUpdateInfoTotal prometheus.Counter proposeBundleUpdateInfoFailureTotal prometheus.Counter bundleBatchesNum prometheus.Gauge - bundleFirstBlockTimeoutReached prometheus.Counter bundleBatchesProposeNotEnoughTotal prometheus.Counter } @@ -70,10 +69,6 @@ func NewBundleProposer(ctx context.Context, cfg *config.BundleProposerConfig, ch Name: "rollup_propose_bundle_batches_number", Help: "The number of batches in the current bundle.", }), - bundleFirstBlockTimeoutReached: promauto.With(reg).NewCounter(prometheus.CounterOpts{ - Name: "rollup_propose_bundle_first_block_timeout_reached_total", - Help: "Total times the first block in a bundle reached the timeout.", - }), bundleBatchesProposeNotEnoughTotal: promauto.With(reg).NewCounter(prometheus.CounterOpts{ Name: "rollup_propose_bundle_batches_propose_not_enough_total", Help: "Total number of times there were not enough batches to propose a bundle.", @@ -125,7 +120,7 @@ func (p *BundleProposer) proposeBundle() error { return err } - // select at most maxBlocksThisChunk blocks + // select at most batchesThisBundle batches batchesThisBundle := p.batchNumPerBundle batches, err := p.batchOrm.GetBatchesGEIndexGECodecVersion(p.ctx, firstUnbundledBatchIndex, encoding.CodecV3, int(batchesThisBundle)) if err != nil { @@ -158,14 +153,13 @@ func (p *BundleProposer) proposeBundle() error { currentHardfork := encoding.GetHardforkName(p.chainCfg, chunk.StartBlockNumber, chunk.StartBlockTime) if currentHardfork != hardforkName { batches = batches[:i] - batchesThisBundle = uint64(i) // update maxBlocksThisChunk to trigger chunking, because these blocks are the last blocks before the hardfork + batchesThisBundle = uint64(i) // update batchesThisBundle as these are the last batches before the hardfork break } } if uint64(len(batches)) == batchesThisBundle { - log.Info("reached number of batches per bundle", "batch count", len(batches), "start batch index", batches[0].Index, "end batch index", batches[len(batches)-1].Index) - p.bundleFirstBlockTimeoutReached.Inc() + log.Info("bundle complete: reached target batch count", "batch count", len(batches), "start batch index", batches[0].Index, "end batch index", batches[len(batches)-1].Index) p.bundleBatchesNum.Set(float64(len(batches))) return p.updateDBBundleInfo(batches, codecVersion) } diff --git a/rollup/internal/controller/watcher/bundle_proposer_test.go b/rollup/internal/controller/watcher/bundle_proposer_test.go index 22703e077..928bab631 100644 --- a/rollup/internal/controller/watcher/bundle_proposer_test.go +++ b/rollup/internal/controller/watcher/bundle_proposer_test.go @@ -34,13 +34,6 @@ func testBundleProposerLimits(t *testing.T) { bundleTimeoutSec: math.MaxUint32, expectedBundlesLen: 0, }, - { - name: "Timeout", - batchNumPerBundle: math.MaxUint64, - bundleTimeoutSec: 0, - expectedBundlesLen: 1, - expectedBatchesInFirstBundle: 2, - }, { name: "maxBatchNumPerBundleIs0", batchNumPerBundle: 0, @@ -143,6 +136,7 @@ func testBundleProposerRespectHardforks(t *testing.T) { BernoulliBlock: big.NewInt(1), CurieBlock: big.NewInt(2), DarwinTime: func() *uint64 { t := uint64(4); return &t }(), + DarwinV2Time: func() *uint64 { t := uint64(4); return &t }(), } // Add genesis batch. @@ -204,7 +198,7 @@ func testBundleProposerRespectHardforks(t *testing.T) { } bup := NewBundleProposer(context.Background(), &config.BundleProposerConfig{ - BatchNumPerBundle: math.MaxUint64, + BatchNumPerBundle: 1, }, chainConfig, db, nil) for i := 0; i < 5; i++ { From 15ff972b3b835918d6b389ea737d815ba4d11756 Mon Sep 17 00:00:00 2001 From: colinlyguo Date: Tue, 19 Nov 2024 13:09:36 +0800 Subject: [PATCH 4/5] fix unit tests --- rollup/tests/rollup_test.go | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/rollup/tests/rollup_test.go b/rollup/tests/rollup_test.go index 4ccf12ac9..3ccb879eb 100644 --- a/rollup/tests/rollup_test.go +++ b/rollup/tests/rollup_test.go @@ -113,7 +113,7 @@ func testCommitBatchAndFinalizeBatchOrBundleWithAllCodecVersions(t *testing.T) { }, chainConfig, db, nil) bup := watcher.NewBundleProposer(context.Background(), &config.BundleProposerConfig{ - BatchNumPerBundle: 1000000, + BatchNumPerBundle: 2, }, chainConfig, db, nil) l2BlockOrm := orm.NewL2Block(db) @@ -279,7 +279,7 @@ func testCommitBatchAndFinalizeBatchOrBundleCrossingAllTransitions(t *testing.T) }, chainConfig, db, nil) bup := watcher.NewBundleProposer(context.Background(), &config.BundleProposerConfig{ - BatchNumPerBundle: 1000000, + BatchNumPerBundle: 1, }, chainConfig, db, nil) cp.TryProposeChunk() From 3f684ed8b0a678c3357f358fd9333c30bc64582f Mon Sep 17 00:00:00 2001 From: colinlyguo Date: Tue, 19 Nov 2024 06:31:22 +0000 Subject: [PATCH 5/5] =?UTF-8?q?chore:=20auto=20version=20bump=E2=80=89[bot?= =?UTF-8?q?]?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- common/version/version.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/common/version/version.go b/common/version/version.go index 01f8a6df5..0f9a7cd89 100644 --- a/common/version/version.go +++ b/common/version/version.go @@ -5,7 +5,7 @@ import ( "runtime/debug" ) -var tag = "v4.4.76" +var tag = "v4.4.77" var commit = func() string { if info, ok := debug.ReadBuildInfo(); ok {