2020-11-13 16:16:47 +00:00
|
|
|
package snapshotsync
|
|
|
|
|
|
|
|
import (
|
2020-11-28 14:26:28 +00:00
|
|
|
"github.com/ledgerwatch/lmdb-go/lmdb"
|
2020-11-13 16:16:47 +00:00
|
|
|
"github.com/ledgerwatch/turbo-geth/common/dbutils"
|
|
|
|
"github.com/ledgerwatch/turbo-geth/ethdb"
|
|
|
|
"github.com/ledgerwatch/turbo-geth/log"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
bucketConfigs = map[SnapshotType]dbutils.BucketsCfg{
|
|
|
|
SnapshotType_bodies: {
|
2021-01-02 19:28:37 +00:00
|
|
|
dbutils.BlockBodyPrefix: dbutils.BucketConfigItem{},
|
|
|
|
dbutils.BodiesSnapshotInfoBucket: dbutils.BucketConfigItem{},
|
2020-11-13 16:16:47 +00:00
|
|
|
},
|
|
|
|
SnapshotType_headers: {
|
2021-01-02 19:28:37 +00:00
|
|
|
dbutils.HeaderPrefix: dbutils.BucketConfigItem{},
|
|
|
|
dbutils.HeadersSnapshotInfoBucket: dbutils.BucketConfigItem{},
|
|
|
|
},
|
|
|
|
SnapshotType_state: {
|
|
|
|
dbutils.PlainStateBucket: dbutils.BucketConfigItem{
|
|
|
|
Flags: dbutils.DupSort,
|
|
|
|
AutoDupSortKeysConversion: true,
|
|
|
|
DupFromLen: 60,
|
|
|
|
DupToLen: 28,
|
|
|
|
},
|
|
|
|
dbutils.PlainContractCodeBucket: dbutils.BucketConfigItem{},
|
|
|
|
dbutils.CodeBucket: dbutils.BucketConfigItem{},
|
|
|
|
dbutils.StateSnapshotInfoBucket: dbutils.BucketConfigItem{},
|
2020-11-13 16:16:47 +00:00
|
|
|
},
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
2021-01-02 19:28:37 +00:00
|
|
|
func WrapBySnapshotsFromDir(kv ethdb.KV, snapshotDir string, mode SnapshotMode) (ethdb.KV, error) {
|
2020-11-13 16:16:47 +00:00
|
|
|
log.Info("Wrap db to snapshots", "dir", snapshotDir, "mode", mode.ToString())
|
2021-01-02 19:28:37 +00:00
|
|
|
snkv := ethdb.NewSnapshot2KV().DB(kv)
|
|
|
|
|
2020-11-13 16:16:47 +00:00
|
|
|
if mode.Bodies {
|
2020-11-28 14:26:28 +00:00
|
|
|
snapshotKV, err := ethdb.NewLMDB().Flags(func(flags uint) uint { return flags | lmdb.Readonly }).Path(snapshotDir + "/bodies").WithBucketsConfig(func(defaultBuckets dbutils.BucketsCfg) dbutils.BucketsCfg {
|
2020-11-13 16:16:47 +00:00
|
|
|
return bucketConfigs[SnapshotType_bodies]
|
2020-11-28 14:26:28 +00:00
|
|
|
}).Open()
|
2020-11-13 16:16:47 +00:00
|
|
|
if err != nil {
|
|
|
|
log.Error("Can't open body snapshot", "err", err)
|
|
|
|
return nil, err
|
|
|
|
} else { //nolint
|
2021-01-02 19:28:37 +00:00
|
|
|
snkv.SnapshotDB([]string{dbutils.BlockBodyPrefix, dbutils.BodiesSnapshotInfoBucket}, snapshotKV)
|
2020-11-13 16:16:47 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if mode.Headers {
|
2020-11-28 14:26:28 +00:00
|
|
|
snapshotKV, err := ethdb.NewLMDB().Flags(func(flags uint) uint { return flags | lmdb.Readonly }).Path(snapshotDir + "/headers").WithBucketsConfig(func(defaultBuckets dbutils.BucketsCfg) dbutils.BucketsCfg {
|
2020-11-13 16:16:47 +00:00
|
|
|
return bucketConfigs[SnapshotType_headers]
|
2020-11-28 14:26:28 +00:00
|
|
|
}).Open()
|
2020-11-13 16:16:47 +00:00
|
|
|
if err != nil {
|
|
|
|
log.Error("Can't open headers snapshot", "err", err)
|
|
|
|
return nil, err
|
|
|
|
} else { //nolint
|
2021-01-02 19:28:37 +00:00
|
|
|
snkv.SnapshotDB([]string{dbutils.HeaderPrefix, dbutils.HeadersSnapshotInfoBucket}, snapshotKV)
|
2020-11-13 16:16:47 +00:00
|
|
|
}
|
|
|
|
}
|
2021-01-02 19:28:37 +00:00
|
|
|
if mode.State {
|
|
|
|
snapshotKV, err := ethdb.NewLMDB().Flags(func(flags uint) uint { return flags | lmdb.Readonly }).Path(snapshotDir + "/headers").WithBucketsConfig(func(defaultBuckets dbutils.BucketsCfg) dbutils.BucketsCfg {
|
|
|
|
return bucketConfigs[SnapshotType_headers]
|
|
|
|
}).Open()
|
|
|
|
if err != nil {
|
|
|
|
log.Error("Can't open headers snapshot", "err", err)
|
|
|
|
return nil, err
|
|
|
|
} else { //nolint
|
|
|
|
snkv.SnapshotDB([]string{dbutils.StateSnapshotInfoBucket, dbutils.PlainStateBucket, dbutils.PlainContractCodeBucket, dbutils.CodeBucket}, snapshotKV)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return snkv.MustOpen(), nil
|
2020-11-13 16:16:47 +00:00
|
|
|
}
|
|
|
|
|
2021-01-02 19:28:37 +00:00
|
|
|
func WrapBySnapshotsFromDownloader(kv ethdb.KV, snapshots map[SnapshotType]*SnapshotsInfo) (ethdb.KV, error) {
|
|
|
|
snKV := ethdb.NewSnapshot2KV().DB(kv)
|
2020-11-13 16:16:47 +00:00
|
|
|
for k, v := range snapshots {
|
|
|
|
log.Info("Wrap db by", "snapshot", k.String(), "dir", v.Dbpath)
|
|
|
|
cfg := bucketConfigs[k]
|
2020-11-28 14:26:28 +00:00
|
|
|
snapshotKV, err := ethdb.NewLMDB().Flags(func(flags uint) uint { return flags | lmdb.Readonly }).Path(v.Dbpath).WithBucketsConfig(func(defaultBuckets dbutils.BucketsCfg) dbutils.BucketsCfg {
|
2020-11-13 16:16:47 +00:00
|
|
|
return cfg
|
2020-11-28 14:26:28 +00:00
|
|
|
}).Open()
|
2021-01-02 19:28:37 +00:00
|
|
|
|
2020-11-13 16:16:47 +00:00
|
|
|
if err != nil {
|
|
|
|
log.Error("Can't open snapshot", "err", err)
|
|
|
|
return nil, err
|
|
|
|
} else { //nolint
|
2021-01-02 19:28:37 +00:00
|
|
|
buckets := make([]string, 0, 1)
|
|
|
|
for bucket := range bucketConfigs[k] {
|
|
|
|
buckets = append(buckets, bucket)
|
2020-11-13 16:16:47 +00:00
|
|
|
}
|
2021-01-02 19:28:37 +00:00
|
|
|
|
|
|
|
snKV.SnapshotDB(buckets, snapshotKV)
|
2020-11-13 16:16:47 +00:00
|
|
|
}
|
|
|
|
}
|
2021-01-02 19:28:37 +00:00
|
|
|
|
|
|
|
return snKV.MustOpen(), nil
|
2020-11-13 16:16:47 +00:00
|
|
|
}
|