2019-11-25 13:46:36 +00:00
|
|
|
package commands
|
|
|
|
|
|
|
|
import (
|
2019-12-04 10:05:35 +00:00
|
|
|
"fmt"
|
2020-01-15 12:47:13 +00:00
|
|
|
"os"
|
|
|
|
"path"
|
|
|
|
"time"
|
2019-12-04 10:05:35 +00:00
|
|
|
|
2020-09-11 20:17:37 +00:00
|
|
|
"github.com/ledgerwatch/turbo-geth/common/dbutils"
|
|
|
|
|
2019-11-25 13:46:36 +00:00
|
|
|
"github.com/ledgerwatch/turbo-geth/cmd/state/stateless"
|
2020-04-04 07:18:10 +00:00
|
|
|
"github.com/ledgerwatch/turbo-geth/ethdb"
|
2019-11-25 13:46:36 +00:00
|
|
|
"github.com/spf13/cobra"
|
|
|
|
)
|
|
|
|
|
|
|
|
func init() {
|
2019-12-03 09:55:15 +00:00
|
|
|
stateGrowthCmd := &cobra.Command{
|
|
|
|
Use: "stateGrowth",
|
|
|
|
Short: "stateGrowth",
|
|
|
|
RunE: func(cmd *cobra.Command, args []string) error {
|
2020-04-04 07:18:10 +00:00
|
|
|
ctx := cmd.Context()
|
|
|
|
|
2020-09-09 10:09:55 +00:00
|
|
|
localDB := ethdb.NewLMDB().Path(file() + "_sg").WithBucketsConfig(func(defaultBuckets dbutils.BucketsCfg) dbutils.BucketsCfg {
|
|
|
|
return dbutils.BucketsCfg{
|
|
|
|
stateless.MainHashesBucket: {},
|
|
|
|
stateless.ReportsProgressBucket: {},
|
|
|
|
}
|
|
|
|
}).MustOpen()
|
2020-03-11 11:02:37 +00:00
|
|
|
|
2021-03-20 03:52:00 +00:00
|
|
|
remoteDB, err := ethdb.NewRemote().Path(privateApiAddr).Open("", "", "")
|
2019-12-03 09:55:15 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2019-12-04 10:05:35 +00:00
|
|
|
fmt.Println("Processing started...")
|
2020-09-09 10:09:55 +00:00
|
|
|
stateless.NewStateGrowth1Reporter(ctx, remoteDB, localDB).StateGrowth1(ctx)
|
|
|
|
stateless.NewStateGrowth2Reporter(ctx, remoteDB, localDB).StateGrowth2(ctx)
|
2019-12-03 09:55:15 +00:00
|
|
|
return nil
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2020-07-27 12:15:48 +00:00
|
|
|
withPrivateApi(stateGrowthCmd)
|
2019-12-03 09:55:15 +00:00
|
|
|
rootCmd.AddCommand(stateGrowthCmd)
|
2019-11-25 13:46:36 +00:00
|
|
|
}
|
2020-01-15 12:47:13 +00:00
|
|
|
|
|
|
|
// Generate name off the file for snapshot
|
|
|
|
// Each day has it's own partition
|
|
|
|
// It means that you can only continue execution of report from last snapshot.Save() checkpoint - read buckets forward from last key
|
|
|
|
// But not re-read bucket
|
|
|
|
func file() string {
|
|
|
|
dir := path.Join(os.TempDir(), "turbo_geth_reports")
|
|
|
|
if err := os.MkdirAll(dir, 0770); err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
return path.Join(dir, time.Now().Format("2006-01-02"))
|
|
|
|
}
|