2022-09-02 13:45:30 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"flag"
|
|
|
|
|
2022-09-10 18:00:03 +00:00
|
|
|
"github.com/c2h5oh/datasize"
|
2022-09-02 13:45:30 +00:00
|
|
|
"github.com/ledgerwatch/erigon-lib/kv/mdbx"
|
|
|
|
"github.com/ledgerwatch/log/v3"
|
|
|
|
)
|
|
|
|
|
2022-09-10 18:00:03 +00:00
|
|
|
type optionsCfg struct {
|
|
|
|
ctx context.Context
|
|
|
|
verkleDb string
|
|
|
|
stateDb string
|
|
|
|
workersCount uint
|
|
|
|
tmpdir string
|
|
|
|
disabledLookups bool
|
|
|
|
}
|
|
|
|
|
|
|
|
func analyseOut(cfg optionsCfg) error {
|
|
|
|
db, err := mdbx.Open(cfg.verkleDb, log.Root(), false)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
defer db.Close()
|
|
|
|
|
|
|
|
tx, err := db.BeginRw(cfg.ctx)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
defer tx.Rollback()
|
|
|
|
if err := initDB(tx); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2022-09-03 17:55:13 +00:00
|
|
|
buckets, err := tx.ListBuckets()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
for _, bucket := range buckets {
|
|
|
|
size, err := tx.BucketSize(bucket)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2022-09-10 18:00:03 +00:00
|
|
|
log.Info("Bucket Analysis", "name", bucket, "size", datasize.ByteSize(size).HumanReadable())
|
2022-09-03 17:55:13 +00:00
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2022-09-02 13:45:30 +00:00
|
|
|
func main() {
|
|
|
|
ctx := context.Background()
|
2022-09-10 18:00:03 +00:00
|
|
|
mainDb := flag.String("state-chaindata", "chaindata", "path to the chaindata database file")
|
|
|
|
verkleDb := flag.String("verkle-chaindata", "out", "path to the output chaindata database file")
|
2022-09-03 17:55:13 +00:00
|
|
|
workersCount := flag.Uint("workers", 5, "amount of goroutines")
|
2022-09-10 18:00:03 +00:00
|
|
|
tmpdir := flag.String("tmpdir", "/tmp/etl-temp", "amount of goroutines")
|
|
|
|
action := flag.String("action", "", "action to execute (hashstate, bucketsizes, verkle)")
|
|
|
|
disableLookups := flag.Bool("disable-lookups", false, "disable lookups generation (more compact database)")
|
2022-09-03 17:55:13 +00:00
|
|
|
|
2022-09-02 13:45:30 +00:00
|
|
|
flag.Parse()
|
|
|
|
log.Root().SetHandler(log.LvlFilterHandler(log.Lvl(3), log.StderrHandler))
|
|
|
|
|
2022-09-10 18:00:03 +00:00
|
|
|
opt := optionsCfg{
|
|
|
|
ctx: ctx,
|
|
|
|
stateDb: *mainDb,
|
|
|
|
verkleDb: *verkleDb,
|
|
|
|
workersCount: *workersCount,
|
|
|
|
tmpdir: *tmpdir,
|
|
|
|
disabledLookups: *disableLookups,
|
2022-09-02 13:45:30 +00:00
|
|
|
}
|
2022-09-03 17:55:13 +00:00
|
|
|
switch *action {
|
2022-09-10 18:00:03 +00:00
|
|
|
case "hashstate":
|
|
|
|
if err := RegeneratePedersenHashstate(opt); err != nil {
|
|
|
|
log.Error("Error", "err", err.Error())
|
|
|
|
}
|
|
|
|
case "bucketsizes":
|
|
|
|
if err := analyseOut(opt); err != nil {
|
|
|
|
log.Error("Error", "err", err.Error())
|
|
|
|
}
|
|
|
|
case "verkle":
|
|
|
|
if err := GenerateVerkleTree(opt); err != nil {
|
2022-09-03 17:55:13 +00:00
|
|
|
log.Error("Error", "err", err.Error())
|
|
|
|
}
|
2022-09-10 18:00:03 +00:00
|
|
|
case "incremental":
|
|
|
|
if err := IncrementVerkleTree(opt); err != nil {
|
2022-09-03 17:55:13 +00:00
|
|
|
log.Error("Error", "err", err.Error())
|
|
|
|
}
|
2022-09-10 18:00:03 +00:00
|
|
|
default:
|
|
|
|
log.Warn("No valid --action specified, aborting")
|
2022-09-03 17:55:13 +00:00
|
|
|
}
|
2022-09-02 13:45:30 +00:00
|
|
|
|
|
|
|
}
|