Some checks failed
Build SimApp / build (amd64) (push) Waiting to run
Build SimApp / build (arm64) (push) Waiting to run
CodeQL / Analyze (push) Waiting to run
Build & Push / build (push) Waiting to run
Run Gosec / Gosec (push) Waiting to run
Lint / golangci-lint (push) Waiting to run
Checks dependencies and mocks generation / Check go mod tidy (push) Waiting to run
Checks dependencies and mocks generation / Check up to date mocks (push) Waiting to run
System Tests / setup (push) Waiting to run
System Tests / test-system (push) Blocked by required conditions
System Tests / test-system-legacy (push) Blocked by required conditions
Tests / Code Coverage / split-test-files (push) Waiting to run
Tests / Code Coverage / tests (00) (push) Blocked by required conditions
Tests / Code Coverage / tests (01) (push) Blocked by required conditions
Tests / Code Coverage / tests (02) (push) Blocked by required conditions
Tests / Code Coverage / tests (03) (push) Blocked by required conditions
Tests / Code Coverage / test-integration (push) Waiting to run
Tests / Code Coverage / test-e2e (push) Waiting to run
Tests / Code Coverage / repo-analysis (push) Blocked by required conditions
Tests / Code Coverage / test-sim-nondeterminism (push) Waiting to run
Tests / Code Coverage / test-clientv2 (push) Waiting to run
Tests / Code Coverage / test-core (push) Waiting to run
Tests / Code Coverage / test-depinject (push) Waiting to run
Tests / Code Coverage / test-errors (push) Waiting to run
Tests / Code Coverage / test-math (push) Waiting to run
Tests / Code Coverage / test-schema (push) Waiting to run
Tests / Code Coverage / test-collections (push) Waiting to run
Tests / Code Coverage / test-cosmovisor (push) Waiting to run
Tests / Code Coverage / test-confix (push) Waiting to run
Tests / Code Coverage / test-store (push) Waiting to run
Tests / Code Coverage / test-log (push) Waiting to run
Tests / Code Coverage / test-x-tx (push) Waiting to run
Tests / Code Coverage / test-x-nft (push) Waiting to run
Tests / Code Coverage / test-x-circuit (push) Waiting to run
Tests / Code Coverage / test-x-feegrant (push) Waiting to run
Tests / Code Coverage / test-x-evidence (push) Waiting to run
Tests / Code Coverage / test-x-upgrade (push) Waiting to run
Tests / Code Coverage / test-tools-benchmark (push) Waiting to run
Build & Push SDK Proto Builder / build (push) Has been cancelled
120 lines
4.2 KiB
Go
120 lines
4.2 KiB
Go
package pruning
|
|
|
|
import (
|
|
"fmt"
|
|
"path/filepath"
|
|
|
|
dbm "github.com/cosmos/cosmos-db"
|
|
"github.com/spf13/cobra"
|
|
"github.com/spf13/viper"
|
|
|
|
"cosmossdk.io/log"
|
|
pruningtypes "cosmossdk.io/store/pruning/types"
|
|
"cosmossdk.io/store/rootmulti"
|
|
|
|
"github.com/cosmos/cosmos-sdk/client/flags"
|
|
"github.com/cosmos/cosmos-sdk/server"
|
|
servertypes "github.com/cosmos/cosmos-sdk/server/types"
|
|
)
|
|
|
|
const FlagAppDBBackend = "app-db-backend"
|
|
|
|
// Cmd prunes the sdk root multi store history versions based on the pruning options
|
|
// specified by command flags.
|
|
func Cmd(appCreator servertypes.AppCreator, defaultNodeHome string) *cobra.Command {
|
|
cmd := &cobra.Command{
|
|
Use: "prune [pruning-method]",
|
|
Short: "Prune app history states by keeping the recent heights and deleting old heights",
|
|
Long: `Prune app history states by keeping the recent heights and deleting old heights.
|
|
The pruning option is provided via the 'pruning' argument or alternatively with '--pruning-keep-recent'
|
|
|
|
- default: the last 362880 states are kept
|
|
- nothing: all historic states will be saved, nothing will be deleted (i.e. archiving node)
|
|
- everything: 2 latest states will be kept
|
|
- custom: allow pruning options to be manually specified through 'pruning-keep-recent'
|
|
|
|
Note: When the --app-db-backend flag is not specified, the default backend type is 'goleveldb'.
|
|
Supported app-db-backend types include 'goleveldb', 'rocksdb', 'pebbledb'.`,
|
|
Example: "prune custom --pruning-keep-recent 100 --app-db-backend 'goleveldb'",
|
|
Args: cobra.RangeArgs(0, 1),
|
|
RunE: func(cmd *cobra.Command, args []string) error {
|
|
// bind flags to the Context's Viper so we can get pruning options.
|
|
vp := viper.New()
|
|
if err := vp.BindPFlags(cmd.Flags()); err != nil {
|
|
return err
|
|
}
|
|
|
|
// force sync pruning so that the command will wait for the pruning to finish before returning.
|
|
vp.Set(server.FlagIAVLSyncPruning, true)
|
|
|
|
// use the first argument if present to set the pruning method
|
|
if len(args) > 0 {
|
|
vp.Set(server.FlagPruning, args[0])
|
|
} else {
|
|
vp.Set(server.FlagPruning, pruningtypes.PruningOptionDefault)
|
|
}
|
|
pruningOptions, err := server.GetPruningOptionsFromFlags(vp)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
cmd.Printf("get pruning options from command flags, strategy: %v, keep-recent: %d, interval: %d\n",
|
|
pruningOptions.Strategy,
|
|
pruningOptions.KeepRecent,
|
|
pruningOptions.Interval,
|
|
)
|
|
|
|
home := vp.GetString(flags.FlagHome)
|
|
if home == "" {
|
|
home = defaultNodeHome
|
|
}
|
|
|
|
db, err := openDB(home, server.GetAppDBBackend(vp))
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
// in our test, it's important to close db explicitly for pebbledb to write to disk.
|
|
defer db.Close()
|
|
|
|
logger := log.NewLogger(cmd.OutOrStdout())
|
|
app := appCreator(logger, db, nil, vp)
|
|
cms := app.CommitMultiStore()
|
|
|
|
rootMultiStore, ok := cms.(*rootmulti.Store)
|
|
if !ok {
|
|
return fmt.Errorf("currently only support the pruning of rootmulti.Store type")
|
|
}
|
|
latestHeight := rootmulti.GetLatestVersion(db)
|
|
// valid heights should be greater than 0.
|
|
if latestHeight <= 0 {
|
|
return fmt.Errorf("the database has no valid heights to prune, the latest height: %v", latestHeight)
|
|
}
|
|
|
|
pruningHeight := latestHeight - int64(pruningOptions.KeepRecent)
|
|
cmd.Printf("pruning heights up to %v\n", pruningHeight)
|
|
|
|
err = rootMultiStore.PruneStores(pruningHeight)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
cmd.Println("successfully pruned the application root multi stores")
|
|
return nil
|
|
},
|
|
}
|
|
|
|
cmd.Flags().String(flags.FlagHome, defaultNodeHome, "The application home directory")
|
|
cmd.Flags().String(FlagAppDBBackend, "", "The type of database for application and snapshots databases")
|
|
cmd.Flags().Uint64(server.FlagPruningKeepRecent, 0, "Number of recent heights to keep on disk (ignored if pruning is not 'custom')")
|
|
cmd.Flags().Uint64(server.FlagPruningInterval, 10,
|
|
`Height interval at which pruned heights are removed from disk (ignored if pruning is not 'custom'),
|
|
this is not used by this command but kept for compatibility with the complete pruning options`)
|
|
|
|
return cmd
|
|
}
|
|
|
|
func openDB(rootDir string, backendType dbm.BackendType) (dbm.DB, error) {
|
|
dataDir := filepath.Join(rootDir, "data")
|
|
return dbm.NewDB("application", backendType, dataDir)
|
|
}
|