[lbry] cli: cleanup
This commit is contained in:
parent
26a4ffe2e3
commit
0377a3e7ac
4 changed files with 42 additions and 44 deletions
|
@ -20,7 +20,7 @@ func NewPebble(path string) (*Pebble, error) {
|
||||||
db, err := pebble.Open(path, &pebble.Options{BytesPerSync: 64 << 20})
|
db, err := pebble.Open(path, &pebble.Options{BytesPerSync: 64 << 20})
|
||||||
repo := &Pebble{db: db}
|
repo := &Pebble{db: db}
|
||||||
|
|
||||||
return repo, errors.Wrapf(err, "unable to open %s", path)
|
return repo, errors.Wrapf(err, "open %s", path)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (repo *Pebble) Save(height int32, changes []change.Change) error {
|
func (repo *Pebble) Save(height int32, changes []change.Change) error {
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"sync"
|
"sync"
|
||||||
|
@ -9,6 +8,7 @@ import (
|
||||||
|
|
||||||
"github.com/btcsuite/btcd/blockchain"
|
"github.com/btcsuite/btcd/blockchain"
|
||||||
"github.com/btcsuite/btcd/claimtrie"
|
"github.com/btcsuite/btcd/claimtrie"
|
||||||
|
"github.com/btcsuite/btcd/claimtrie/chain"
|
||||||
"github.com/btcsuite/btcd/claimtrie/chain/chainrepo"
|
"github.com/btcsuite/btcd/claimtrie/chain/chainrepo"
|
||||||
"github.com/btcsuite/btcd/claimtrie/change"
|
"github.com/btcsuite/btcd/claimtrie/change"
|
||||||
"github.com/btcsuite/btcd/claimtrie/config"
|
"github.com/btcsuite/btcd/claimtrie/config"
|
||||||
|
@ -43,6 +43,7 @@ func NewChainCommands() *cobra.Command {
|
||||||
|
|
||||||
func NewChainDumpCommand() *cobra.Command {
|
func NewChainDumpCommand() *cobra.Command {
|
||||||
|
|
||||||
|
var chainRepoPath string
|
||||||
var fromHeight int32
|
var fromHeight int32
|
||||||
var toHeight int32
|
var toHeight int32
|
||||||
|
|
||||||
|
@ -52,7 +53,7 @@ func NewChainDumpCommand() *cobra.Command {
|
||||||
Args: cobra.NoArgs,
|
Args: cobra.NoArgs,
|
||||||
RunE: func(cmd *cobra.Command, args []string) error {
|
RunE: func(cmd *cobra.Command, args []string) error {
|
||||||
|
|
||||||
dbPath := filepath.Join(dataDir, netName, "claim_dbs", cfg.ChainRepoPebble.Path)
|
dbPath := chainRepoPath
|
||||||
log.Debugf("Open chain repo: %q", dbPath)
|
log.Debugf("Open chain repo: %q", dbPath)
|
||||||
chainRepo, err := chainrepo.NewPebble(dbPath)
|
chainRepo, err := chainrepo.NewPebble(dbPath)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -76,6 +77,7 @@ func NewChainDumpCommand() *cobra.Command {
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
cmd.Flags().StringVar(&chainRepoPath, "chaindb", "chain_db", "Claim operation database")
|
||||||
cmd.Flags().Int32Var(&fromHeight, "from", 0, "From height (inclusive)")
|
cmd.Flags().Int32Var(&fromHeight, "from", 0, "From height (inclusive)")
|
||||||
cmd.Flags().Int32Var(&toHeight, "to", 0, "To height (inclusive)")
|
cmd.Flags().Int32Var(&toHeight, "to", 0, "To height (inclusive)")
|
||||||
cmd.Flags().SortFlags = false
|
cmd.Flags().SortFlags = false
|
||||||
|
@ -85,6 +87,7 @@ func NewChainDumpCommand() *cobra.Command {
|
||||||
|
|
||||||
func NewChainReplayCommand() *cobra.Command {
|
func NewChainReplayCommand() *cobra.Command {
|
||||||
|
|
||||||
|
var chainRepoPath string
|
||||||
var fromHeight int32
|
var fromHeight int32
|
||||||
var toHeight int32
|
var toHeight int32
|
||||||
|
|
||||||
|
@ -108,9 +111,8 @@ func NewChainReplayCommand() *cobra.Command {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
dbPath := filepath.Join(dataDir, netName, "claim_dbs", cfg.ChainRepoPebble.Path)
|
log.Debugf("Open chain repo: %q", chainRepoPath)
|
||||||
log.Debugf("Open chain repo: %q", dbPath)
|
chainRepo, err := chainrepo.NewPebble(chainRepoPath)
|
||||||
chainRepo, err := chainrepo.NewPebble(dbPath)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return errors.Wrapf(err, "open chain repo")
|
return errors.Wrapf(err, "open chain repo")
|
||||||
}
|
}
|
||||||
|
@ -135,6 +137,7 @@ func NewChainReplayCommand() *cobra.Command {
|
||||||
return errors.Wrapf(err, "load chain")
|
return errors.Wrapf(err, "load chain")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
startTime := time.Now()
|
||||||
for ht := fromHeight; ht < toHeight; ht++ {
|
for ht := fromHeight; ht < toHeight; ht++ {
|
||||||
|
|
||||||
changes, err := chainRepo.Load(ht + 1)
|
changes, err := chainRepo.Load(ht + 1)
|
||||||
|
@ -170,8 +173,9 @@ func NewChainReplayCommand() *cobra.Command {
|
||||||
return errors.Wrapf(err, "appendBlock")
|
return errors.Wrapf(err, "appendBlock")
|
||||||
}
|
}
|
||||||
|
|
||||||
if ct.Height()%1000 == 0 {
|
if time.Since(startTime) > 5*time.Second {
|
||||||
fmt.Printf("block: %d\n", ct.Height())
|
log.Infof("Block: %d", ct.Height())
|
||||||
|
startTime = time.Now()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -179,7 +183,7 @@ func NewChainReplayCommand() *cobra.Command {
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
// FIXME
|
cmd.Flags().StringVar(&chainRepoPath, "chaindb", "chain_db", "Claim operation database")
|
||||||
cmd.Flags().Int32Var(&fromHeight, "from", 0, "From height")
|
cmd.Flags().Int32Var(&fromHeight, "from", 0, "From height")
|
||||||
cmd.Flags().Int32Var(&toHeight, "to", 0, "To height")
|
cmd.Flags().Int32Var(&toHeight, "to", 0, "To height")
|
||||||
cmd.Flags().SortFlags = false
|
cmd.Flags().SortFlags = false
|
||||||
|
@ -209,11 +213,12 @@ func appendBlock(ct *claimtrie.ClaimTrie, chain *blockchain.BlockChain) error {
|
||||||
|
|
||||||
func NewChainConvertCommand() *cobra.Command {
|
func NewChainConvertCommand() *cobra.Command {
|
||||||
|
|
||||||
var height int32
|
var chainRepoPath string
|
||||||
|
var toHeight int32
|
||||||
|
|
||||||
cmd := &cobra.Command{
|
cmd := &cobra.Command{
|
||||||
Use: "convert",
|
Use: "convert",
|
||||||
Short: "convert changes from to <height>",
|
Short: "convert changes from 0 to <toHeight>",
|
||||||
Args: cobra.NoArgs,
|
Args: cobra.NoArgs,
|
||||||
RunE: func(cmd *cobra.Command, args []string) error {
|
RunE: func(cmd *cobra.Command, args []string) error {
|
||||||
|
|
||||||
|
@ -228,9 +233,21 @@ func NewChainConvertCommand() *cobra.Command {
|
||||||
return errors.Wrapf(err, "load block db")
|
return errors.Wrapf(err, "load block db")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if toHeight > chain.BestSnapshot().Height {
|
||||||
|
toHeight = chain.BestSnapshot().Height
|
||||||
|
}
|
||||||
|
|
||||||
|
chainRepo, err := chainrepo.NewPebble(chainRepoPath)
|
||||||
|
if err != nil {
|
||||||
|
return errors.Wrapf(err, "open chain repo: %v")
|
||||||
|
}
|
||||||
|
defer chainRepo.Close()
|
||||||
|
|
||||||
converter := chainConverter{
|
converter := chainConverter{
|
||||||
db: db,
|
db: db,
|
||||||
chain: chain,
|
chain: chain,
|
||||||
|
chainRepo: chainRepo,
|
||||||
|
toHeight: toHeight,
|
||||||
blockChan: make(chan *btcutil.Block, 1000),
|
blockChan: make(chan *btcutil.Block, 1000),
|
||||||
changesChan: make(chan []change.Change, 1000),
|
changesChan: make(chan []change.Change, 1000),
|
||||||
wg: &sync.WaitGroup{},
|
wg: &sync.WaitGroup{},
|
||||||
|
@ -250,8 +267,9 @@ func NewChainConvertCommand() *cobra.Command {
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
cmd.Flags().Int32Var(&height, "height", 0, "Height")
|
cmd.Flags().StringVar(&chainRepoPath, "chaindb", "chain_db", "Claim operation database")
|
||||||
|
cmd.Flags().Int32Var(&toHeight, "to", 0, "toHeight")
|
||||||
|
cmd.Flags().SortFlags = false
|
||||||
return cmd
|
return cmd
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -262,8 +280,10 @@ type stat struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
type chainConverter struct {
|
type chainConverter struct {
|
||||||
db database.DB
|
db database.DB
|
||||||
chain *blockchain.BlockChain
|
chain *blockchain.BlockChain
|
||||||
|
chainRepo chain.Repo
|
||||||
|
toHeight int32
|
||||||
|
|
||||||
blockChan chan *btcutil.Block
|
blockChan chan *btcutil.Block
|
||||||
changesChan chan []change.Change
|
changesChan chan []change.Change
|
||||||
|
@ -293,18 +313,13 @@ func (cb *chainConverter) getBlock() {
|
||||||
defer cb.wg.Done()
|
defer cb.wg.Done()
|
||||||
defer close(cb.blockChan)
|
defer close(cb.blockChan)
|
||||||
|
|
||||||
toHeight := int32(200000)
|
for ht := int32(0); ht < cb.toHeight; ht++ {
|
||||||
fmt.Printf("blocks: %d\n", cb.chain.BestSnapshot().Height)
|
|
||||||
|
|
||||||
if toHeight > cb.chain.BestSnapshot().Height {
|
|
||||||
toHeight = cb.chain.BestSnapshot().Height
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
for ht := int32(0); ht < toHeight; ht++ {
|
|
||||||
block, err := cb.chain.BlockByHeight(ht)
|
block, err := cb.chain.BlockByHeight(ht)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Errorf("load changes from repo: %w", err)
|
if errors.Cause(err).Error() == "too many open files" {
|
||||||
|
err = errors.WithHintf(err, "try ulimit -n 2048")
|
||||||
|
}
|
||||||
|
log.Errorf("load changes at %d: %s", ht, err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
cb.stat.blocksFetched++
|
cb.stat.blocksFetched++
|
||||||
|
@ -401,16 +416,8 @@ func (cb *chainConverter) processBlock() {
|
||||||
func (cb *chainConverter) saveChanges() {
|
func (cb *chainConverter) saveChanges() {
|
||||||
defer cb.wg.Done()
|
defer cb.wg.Done()
|
||||||
|
|
||||||
dbPath := filepath.Join(dataDir, netName, "claim_dbs", cfg.ChainRepoPebble.Path)
|
|
||||||
chainRepo, err := chainrepo.NewPebble(dbPath)
|
|
||||||
if err != nil {
|
|
||||||
log.Errorf("open chain repo: %s", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
defer chainRepo.Close()
|
|
||||||
|
|
||||||
for changes := range cb.changesChan {
|
for changes := range cb.changesChan {
|
||||||
err = chainRepo.Save(changes[0].Height, changes)
|
err := cb.chainRepo.Save(changes[0].Height, changes)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Errorf("save to chain repo: %s", err)
|
log.Errorf("save to chain repo: %s", err)
|
||||||
return
|
return
|
||||||
|
|
|
@ -39,7 +39,7 @@ func NewRootCommand() *cobra.Command {
|
||||||
}
|
}
|
||||||
|
|
||||||
cmd.PersistentFlags().StringVar(&netName, "netname", "mainnet", "Net name")
|
cmd.PersistentFlags().StringVar(&netName, "netname", "mainnet", "Net name")
|
||||||
cmd.PersistentFlags().StringVar(&dataDir, "datadir", cfg.DataDir, "Data dir")
|
cmd.PersistentFlags().StringVarP(&dataDir, "datadir", "b", cfg.DataDir, "Data dir")
|
||||||
|
|
||||||
return cmd
|
return cmd
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,12 +26,6 @@ var DefaultConfig = Config{
|
||||||
MerkleTrieRepoPebble: pebbleConfig{
|
MerkleTrieRepoPebble: pebbleConfig{
|
||||||
Path: "merkletrie_pebble_db",
|
Path: "merkletrie_pebble_db",
|
||||||
},
|
},
|
||||||
ChainRepoPebble: pebbleConfig{
|
|
||||||
Path: "chain_pebble_db",
|
|
||||||
},
|
|
||||||
ReportedBlockRepoPebble: pebbleConfig{
|
|
||||||
Path: "reported_blocks_pebble_db",
|
|
||||||
},
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Config is the container of all configurations.
|
// Config is the container of all configurations.
|
||||||
|
@ -46,9 +40,6 @@ type Config struct {
|
||||||
NodeRepoPebble pebbleConfig
|
NodeRepoPebble pebbleConfig
|
||||||
TemporalRepoPebble pebbleConfig
|
TemporalRepoPebble pebbleConfig
|
||||||
MerkleTrieRepoPebble pebbleConfig
|
MerkleTrieRepoPebble pebbleConfig
|
||||||
|
|
||||||
ChainRepoPebble pebbleConfig
|
|
||||||
ReportedBlockRepoPebble pebbleConfig
|
|
||||||
}
|
}
|
||||||
|
|
||||||
type pebbleConfig struct {
|
type pebbleConfig struct {
|
||||||
|
|
Loading…
Add table
Reference in a new issue