State sync
info
State synchronization enables a new node to seamlessly integrate into the network by retrieving a snapshot of the application state at a recent height, rather than fetching and replaying all historical blocks. Given that the application state is typically more compact than the blocks themselves, and the restoration process is significantly quicker than block replay, this method can drastically diminish the network synchronization duration from days to mere minutes.
Instructionsโ
Stop the service and reset the dataโ
sudo systemctl stop initiad
cp $HOME/.initia/data/priv_validator_state.json $HOME/.initia/priv_validator_state.json.backup
initiad tendermint unsafe-reset-all --keep-addr-book --home $HOME/.initia
Get and configure the state sync informationโ
STATE_SYNC_RPC=https://initia-testnet-rpc.owlstake.com
STATE_SYNC_PEER=3f4a220afa0158a1bea844a621ce89080e44fc61@103.107.183.89:26656
LATEST_HEIGHT=$(curl -s $STATE_SYNC_RPC/block | jq -r .result.block.header.height)
SYNC_BLOCK_HEIGHT=$(($LATEST_HEIGHT - 1000))
SYNC_BLOCK_HASH=$(curl -s "$STATE_SYNC_RPC/block?height=$SYNC_BLOCK_HEIGHT" | jq -r .result.block_id.hash)
sed -i \
-e "s|^enable *=.*|enable = true|" \
-e "s|^rpc_servers *=.*|rpc_servers = \"$STATE_SYNC_RPC,$STATE_SYNC_RPC\"|" \
-e "s|^trust_height *=.*|trust_height = $SYNC_BLOCK_HEIGHT|" \
-e "s|^trust_hash *=.*|trust_hash = \"$SYNC_BLOCK_HASH\"|" \
-e "s|^persistent_peers *=.*|persistent_peers = \"$STATE_SYNC_PEER\"|" \
$HOME/.initia/config/config.toml
mv $HOME/.initia/priv_validator_state.json.backup $HOME/.initia/data/priv_validator_state.json
Download latest wasmโ
info
Currently state sync does not support copy of the wasm
folder. Therefore, you will have to download it manually.
curl -L https://snapshots.owlstake.com/initiation-1/wasm_latest.tar.lz4 | lz4 -dc - | tar -xf - -C $HOME/.initia
Restart the service and check the logโ
sudo systemctl start initiad && sudo journalctl -u initiad -f --no-hostname -o cat