mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2024-12-31 16:21:21 +00:00
Warmup logs, less overhead, warmup code bucket (#1054)
* warmup logs and less overhead. * warmup logs and less overhead. * move WarmUp to common func
This commit is contained in:
parent
9d29a4b480
commit
c45a710ce6
@ -103,19 +103,14 @@ func SpawnExecuteBlocksStage(s *StageState, stateDB ethdb.Database, chainConfig
|
||||
|
||||
if warmup {
|
||||
log.Info("Running a warmup...")
|
||||
count := 0
|
||||
if err := stateDB.Walk(dbutils.PlainStateBucket, nil, 0, func(_, _ []byte) (bool, error) {
|
||||
if err := common.Stopped(quit); err != nil {
|
||||
return false, nil
|
||||
}
|
||||
count++
|
||||
if count%10000000 == 0 {
|
||||
log.Info("Warmed up", "keys", count)
|
||||
}
|
||||
return true, nil
|
||||
}); err != nil {
|
||||
if err := ethdb.WarmUp(tx.(ethdb.HasTx).Tx(), dbutils.PlainStateBucket, logEvery, quit); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
if err := ethdb.WarmUp(tx.(ethdb.HasTx).Tx(), dbutils.CodeBucket, logEvery, quit); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
warmup = false
|
||||
log.Info("Warm up done.")
|
||||
}
|
||||
|
@ -132,6 +132,8 @@ type Cursor interface {
|
||||
// new data is the same size as the old. Otherwise it will simply
|
||||
// perform a delete of the old record followed by an insert.
|
||||
PutCurrent(key, value []byte) error
|
||||
|
||||
Count() (uint64, error) // Count - fast way to calculate amount of keys in bucket. It counts all keys even if Prefix was set.
|
||||
}
|
||||
|
||||
type CursorDupSort interface {
|
||||
|
@ -306,6 +306,7 @@ func (c *boltCursor) PutCurrent(key, value []byte) error { panic("not
|
||||
func (c *boltCursor) Current() ([]byte, []byte, error) { panic("not supported") }
|
||||
func (c *boltCursor) Last() (k, v []byte, err error) { panic("not implemented yet") }
|
||||
func (c *boltCursor) PutNoOverwrite(key []byte, value []byte) error { panic("not implemented yet") }
|
||||
func (c *boltCursor) Count() (uint64, error) { panic("not supported") }
|
||||
|
||||
func (c *boltCursor) SeekExact(key []byte) (val []byte, err error) {
|
||||
return c.bucket.Get(key)
|
||||
|
@ -617,6 +617,14 @@ func (c *LmdbCursor) initCursor() error {
|
||||
return nil
|
||||
}
|
||||
|
||||
func (c *LmdbCursor) Count() (uint64, error) {
|
||||
st, err := c.tx.tx.Stat(c.bucketCfg.DBI)
|
||||
if err != nil {
|
||||
return 0, err
|
||||
}
|
||||
return st.Entries, nil
|
||||
}
|
||||
|
||||
func (c *LmdbCursor) First() ([]byte, []byte, error) {
|
||||
if c.c == nil {
|
||||
if err := c.initCursor(); err != nil {
|
||||
|
@ -261,6 +261,7 @@ func (c *remoteCursor) PutCurrent(key, value []byte) error { panic("n
|
||||
func (c *remoteCursor) Append(key []byte, value []byte) error { panic("not supported") }
|
||||
func (c *remoteCursor) Delete(key []byte) error { panic("not supported") }
|
||||
func (c *remoteCursor) DeleteCurrent() error { panic("not supported") }
|
||||
func (c *remoteCursor) Count() (uint64, error) { panic("not supported") }
|
||||
|
||||
func (c *remoteCursor) First() ([]byte, []byte, error) {
|
||||
return c.Seek(c.prefix)
|
||||
|
@ -29,6 +29,7 @@ import (
|
||||
"github.com/ledgerwatch/turbo-geth/log"
|
||||
"github.com/ledgerwatch/turbo-geth/metrics"
|
||||
"strings"
|
||||
"time"
|
||||
)
|
||||
|
||||
var (
|
||||
@ -447,3 +448,28 @@ func NewDatabaseWithFreezer(db *ObjectDatabase, dir, suffix string) (*ObjectData
|
||||
// FIXME: implement freezer in Turbo-Geth
|
||||
return db, nil
|
||||
}
|
||||
|
||||
func WarmUp(tx Tx, bucket string, logEvery *time.Ticker, quit <-chan struct{}) error {
|
||||
count := 0
|
||||
c := tx.Cursor(bucket)
|
||||
totalKeys, errCount := c.Count()
|
||||
if errCount != nil {
|
||||
return errCount
|
||||
}
|
||||
for k, _, err := c.First(); k != nil; k, _, err = c.Next() {
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
count++
|
||||
|
||||
select {
|
||||
default:
|
||||
case <-quit:
|
||||
return common.ErrStopped
|
||||
case <-logEvery.C:
|
||||
log.Info("Warmed up state", "progress", fmt.Sprintf("%.2fM/%.2fM", float64(count)/1_000_000, float64(totalKeys)/1_000_000))
|
||||
}
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user