core: preallocate batch size in bloomIndexer (#25289)
This change reduces allocations when committing bloombits indexes by creating the database batch with a larger initial size.
This commit is contained in:
parent
da977e9cdc
commit
e9a04cca30
@ -75,7 +75,7 @@ func (b *BloomIndexer) Process(ctx context.Context, header *types.Header) error
|
||||
// Commit implements core.ChainIndexerBackend, finalizing the bloom section and
|
||||
// writing it out into the database.
|
||||
func (b *BloomIndexer) Commit() error {
|
||||
batch := b.db.NewBatch()
|
||||
batch := b.db.NewBatchWithSize((int(b.size) / 8) * types.BloomBitLength)
|
||||
for i := 0; i < types.BloomBitLength; i++ {
|
||||
bits, err := b.gen.Bitset(uint(i))
|
||||
if err != nil {
|
||||
|
@ -189,6 +189,7 @@ func (t *table) DiffStore() ethdb.KeyValueStore {
|
||||
func (t *table) SetDiffStore(diff ethdb.KeyValueStore) {
|
||||
panic("not implement")
|
||||
}
|
||||
|
||||
// NewBatchWithSize creates a write-only database batch with pre-allocated buffer.
|
||||
func (t *table) NewBatchWithSize(size int) ethdb.Batch {
|
||||
return &tableBatch{t.db.NewBatchWithSize(size), t.prefix}
|
||||
|
Loading…
Reference in New Issue
Block a user