Cheat Sheet
A Tendermint cheat sheet is a quick reference for essential commands to control Tendermint blockchains.
Managing keys
Managing keys on a Tendermint-based chain involves securing and controlling access to cryptographic keys used for chain operations.
Generate new key
quasarnoded keys add wallet
Recover key
quasarnoded keys add wallet --recover
List all key
quasarnoded keys list
Delete key
quasarnoded keys delete wallet
Export key
quasarnoded keys export wallet
Import key
quasarnoded keys import wallet wallet.backup
Query wallet balances
quasarnoded q bank balances $(quasarnoded keys show wallet -a)
Managing validators
Ensure you've updated moniker, identity, details, and website to match your values.
Create validator
quasarnoded tx staking create-validator \
--amount 1000000uqsr \
--pubkey $(quasarnoded tendermint show-validator) \
--moniker "your-moniker-name" \
--identity "your-keybase-id" \
--details "your-details" \
--website "your-website" \
--security-contact "your-email" \
--chain-id quasar-test-1 \
--commission-rate 0.05 \
--commission-max-rate 0.20 \
--commission-max-change-rate 0.01 \
--min-self-delegation 1 \
--from wallet \
--gas-adjustment 1.4 \
--gas auto \
--gas-prices 0uqsr \
-y
Edit validator
quasarnoded tx staking edit-validator \
--new-moniker "your-moniker-name" \
--identity "your-keybase-id" \
--details "your-details" \
--website "your-website" \
--security-contact "your-email" \
--chain-id quasar-test-1 \
--commission-rate 0.05 \
--from wallet \
--gas-adjustment 1.4 \
--gas auto \
--gas-prices 0uqsr \
-y
Unjail validator
quasarnoded tx slashing unjail --from wallet --chain-id quasar-test-1 --gas-adjustment 1.4 --gas auto --gas-prices 0uqsr -y
Validator jail reason
quasarnoded query slashing signing-info $(quasarnoded tendermint show-validator)
List active validator
quasarnoded q staking validators -oj --limit=3000 | jq '.validators[] | select(.status=="BOND_STATUS_BONDED")' | jq -r '(.tokens|tonumber/pow(10; 6)|floor|tostring) + " \t " + .description.moniker' | sort -gr | nl
List incative validator
quasarnoded q staking validators -oj --limit=3000 | jq '.validators[] | select(.status=="BOND_STATUS_UNBONDED")' | jq -r '(.tokens|tonumber/pow(10; 6)|floor|tostring) + " \t " + .description.moniker' | sort -gr | nl
View validator details
quasarnoded q staking validator $(quasarnoded keys show wallet --bech val -a)
Managing Tokens
Withdraw reward from all validator
quasarnoded tx distribution withdraw-all-rewards --from wallet --chain-id quasar-test-1 --gas-adjustment 1.4 --gas auto --gas-prices 0uqsr -y
Withdraw reward and commission
quasarnoded tx distribution withdraw-rewards $(quasarnoded keys show wallet --bech val -a) --commission --from wallet --chain-id quasar-test-1 --gas-adjustment 1.4 --gas auto --gas-prices 0uqsr -y
Delegate tokens to your validator
quasarnoded tx staking delegate $(quasarnoded keys show wallet --bech val -a) 1000000uqsr --from wallet --chain-id quasar-test-1 --gas-adjustment 1.4 --gas auto --gas-prices 0uqsr -y
Delegate token to other validator, change <to-valoper-address> as you like
quasarnoded tx staking delegate <to-valoper-address> 1000000uqsr --from wallet --chain-id quasar-test-1 --gas-adjustment 1.4 --gas auto --gas-prices 0uqsr -y
Redelegate to another validator
quasarnoded tx staking redelegate $(quasarnoded keys show wallet --bech val -a) <to-valoper-address> 1000000uqsr --from wallet --chain-id quasar-test-1 --gas-adjustment 1.4 --gas auto --gas-prices 0uqsr -y
Unbond token from your own validator
quasarnoded tx staking unbond $(quasarnoded keys show wallet --bech val -a) 1000000uqsr --from wallet --chain-id quasar-test-1 --gas-adjustment 1.4 --gas auto --gas-prices 0uqsr -y
Send token to the wallet
quasarnoded tx bank send wallet <to-wallet-address> 1000000uqsr --from wallet --chain-id quasar-test-1 --gas-adjustment 1.4 --gas auto --gas-prices 0uqsr -y
Governance
Query list proposal
quasarnoded query gov proposals
View proposal by ID
quasarnoded query gov proposal 1
Vote option yes
quasarnoded tx gov vote 1 yes --from wallet --chain-id quasar-test-1 --gas-adjustment 1.4 --gas auto --gas-prices 0uqsr -y
Vote option no
quasarnoded tx gov vote 1 no --from wallet --chain-id quasar-test-1 --gas-adjustment 1.4 --gas auto --gas-prices 0uqsr -y
Vote option asbtain
quasarnoded tx gov vote 1 abstain --from wallet --chain-id quasar-test-1 --gas-adjustment 1.4 --gas auto --gas-prices 0uqsr -y
Vote option NoWithVeto
quasarnoded tx gov vote 1 NoWithVeto --from wallet --chain-id quasar-test-1 --gas-adjustment 1.4 --gas auto --gas-prices 0uqsr -y
Usefulness
Please note that updating the custom port is optional!
Update custom port
CUSTOM_PORT=221
sed -i -e "s%^proxy_app = \"tcp://127.0.0.1:26658\"%proxy_app = \"tcp://127.0.0.1:${CUSTOM_PORT}58\"%; s%^laddr = \"tcp://127.0.0.1:26657\"%laddr = \"tcp://127.0.0.1:${CUSTOM_PORT}57\"%; s%^pprof_laddr = \"localhost:6060\"%pprof_laddr = \"localhost:${CUSTOM_PORT}60\"%; s%^laddr = \"tcp://0.0.0.0:26656\"%laddr = \"tcp://0.0.0.0:${CUSTOM_PORT}56\"%; s%^prometheus_listen_addr = \":26660\"%prometheus_listen_addr = \":${CUSTOM_PORT}66\"%" $HOME/.quasarnode/config/config.toml
sed -i -e "s%^address = \"tcp://0.0.0.0:1317\"%address = \"tcp://0.0.0.0:${CUSTOM_PORT}17\"%; s%^address = \":8080\"%address = \":${CUSTOM_PORT}80\"%; s%^address = \"0.0.0.0:9090\"%address = \"0.0.0.0:${CUSTOM_PORT}90\"%; s%^address = \"0.0.0.0:9091\"%address = \"0.0.0.0:${CUSTOM_PORT}91\"%" $HOME/.quasarnode/config/app.toml
Disable indexer
sed -i -e 's|^indexer *=.*|indexer = "null"|' $HOME/.quasarnode/config/config.toml
Enable indexer
sed -i -e 's|^indexer *=.*|indexer = "kv"|' $HOME/.quasarnode/config/config.toml
Pruning update
sed -i \
-e 's|^pruning *=.*|pruning = "custom"|' \
-e 's|^pruning-keep-recent *=.*|pruning-keep-recent = "100"|' \
-e 's|^pruning-keep-every *=.*|pruning-keep-every = "0"|' \
-e 's|^pruning-interval *=.*|pruning-interval = "19"|' \
$HOME/.quasarnode/config/app.toml
Maintenance
Get validator information
quasarnoded status 2>&1 | jq .ValidatorInfo
Get sync information
quasarnoded status 2>&1 | jq .SyncInfo
Get node peer
echo $(quasarnoded tendermint show-node-id)'@'$(curl -s ifconfig.me)':'$(cat $HOME/.quasarnode/config/config.toml | sed -n '/Address to listen for incoming connection/{n;p;}' | sed 's/.*://; s/".*//')
Check validator keys
[[ $(quasarnoded q staking validator $(quasarnoded keys show wallet --bech val -a) -oj | jq -r .consensus_pubkey.key) = $(quasarnoded status | jq -r .ValidatorInfo.PubKey.value) ]] && echo -e "\n\e[1m\e[32mTrue\e[0m\n" || echo -e "\n\e[1m\e[31mFalse\e[0m\n"
Get live peers
curl -sS http://localhost:22157/net_info | jq -r '.result.peers[] | "\(.node_info.id)@\(.remote_ip):\(.node_info.listen_addr)"' | awk -F ':' '{print $1":"$(NF)}'
Configure minimum gas prices
sed -i -e "s/^minimum-gas-prices *=.*/minimum-gas-prices = \"0.0025uqsr\"/" $HOME/.quasarnode/config/app.toml
Enable prometheus
sed -i -e "s/prometheus = false/prometheus = true/" $HOME/.quasarnode/config/config.toml
Reset chain data
quasarnoded tendermint unsafe-reset-all --keep-addr-book --home $HOME/.quasarnode --keep-addr-book
π¨
Before moving on to the next step, be aware that all chain data will be erased. Ensure you've created a backup of your priv_validator_key.json!
Remove node
cd $HOME
sudo systemctl stop quasar
sudo systemctl disable quasar
sudo rm /etc/systemd/system/quasar.service
sudo systemctl daemon-reload
sudo rm -f $(which quasarnoded)
sudo rm -rf $HOME/.quasarnode
sudo rm -rf $HOME/quasar
sudo rm -rf $HOME/go