KYVE Validator Tools & Infrastructure Documentation
Complete infrastructure toolkit for KYVE validators and developers. Access our professional-grade services including RPC nodes, API endpoints, daily snapshots, and real-time metrics. Our kyve infrastructure features optimized pruning configurations, automated backups, and comprehensive monitoring solutions. Supporting both mainnet and testnet environments with dedicated endpoints, state-sync services, and detailed technical documentation for seamless network participation and development.
Useful set of commands for node operators. From key management to chain governance.
#Daemon configuration
kyved config node https://rpc.lavenderfive.com:443/kyve
kyved config chain-id kyve-1
#๐ Key management
#Add new key
kyved keys add wallet
#Recover existing key
kyved keys add wallet --recover
#List all keys
kyved keys list
#Delete key
kyved keys delete wallet
#Export key to the file
kyved keys export wallet
#Import key from the file
kyved keys import wallet wallet.backup
#Query wallet balance
kyved q bank balances $(kyved keys show wallet -a)
#๐ท Validator management
โย ย ย
Please make sure you have adjusted **moniker**, **identity**, **details** and **website** to match your values.
#Create new validator
kyved tx staking create-validator \
--amount 2ukyve \
--pubkey $(kyved tendermint show-validator) \
--moniker "YOUR_MONIKER_NAME" \
--identity "YOUR_KEYBASE_ID" \
--details "YOUR_DETAILS" \
--website "YOUR_WEBSITE_URL" \
--chain-id kyve-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 2ukyve \
-y
#Edit existing validator
kyved tx staking edit-validator \
--new-moniker "YOUR_MONIKER_NAME" \
--identity "YOUR_KEYBASE_ID" \
--details "YOUR_DETAILS" \
--website "YOUR_WEBSITE_URL" \
--chain-id kyve-1 \
--commission-rate 0.05 \
--from wallet \
--gas-adjustment 1.4 \
--gas auto \
--gas-prices 2ukyve \
-y
#Unjail validator
kyved tx slashing unjail --from wallet --chain-id kyve-1 --gas-adjustment 1.4 --gas auto --gas-prices 2ukyve -y
#Jail reason
kyved query slashing signing-info $(kyved tendermint show-validator)
#List all active validators
kyved 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 all inactive validators
kyved 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
kyved q staking validator $(kyved keys show wallet --bech val -a)
#๐ฒ Token management
#Withdraw rewards from all validators
kyved tx distribution withdraw-all-rewards --from wallet --chain-id kyve-1 --gas-adjustment 1.4 --gas auto --gas-prices 2ukyve -y
#Withdraw commission and rewards from your validator
kyved tx distribution withdraw-rewards $(kyved keys show wallet --bech val -a) --commission --from wallet --chain-id kyve-1 --gas-adjustment 1.4 --gas auto --gas-prices 2ukyve -y
#Delegate tokens to yourself
kyved tx staking delegate $(kyved keys show wallet --bech val -a) 2ukyve --from wallet --chain-id kyve-1 --gas-adjustment 1.4 --gas auto --gas-prices 2ukyve -y
#Delegate tokens to validator
kyved tx staking delegate 2ukyve --from wallet --chain-id kyve-1 --gas-adjustment 1.4 --gas auto --gas-prices 2ukyve -y
#Redelegate tokens to another validator
kyved tx staking redelegate $(kyved keys show wallet --bech val -a) 2ukyve --from wallet --chain-id kyve-1 --gas-adjustment 1.4 --gas auto --gas-prices 2ukyve -y
#Unbond tokens from your validator
kyved tx staking unbond $(kyved keys show wallet --bech val -a) 2ukyve --from wallet --chain-id kyve-1 --gas-adjustment 1.4 --gas auto --gas-prices 2ukyve -y
#Send tokens to the wallet
kyved tx bank send wallet 2ukyve --from wallet --chain-id kyve-1 --gas-adjustment 1.4 --gas auto --gas-prices 2ukyve -y
#๐ณ Governance
#List all proposals
kyved query gov proposals
#View proposal by id
kyved query gov proposal 1
#Vote 'Yes'
kyved tx gov vote 1 yes --from wallet --chain-id kyve-1 --gas-adjustment 1.4 --gas auto --gas-prices 2ukyve -y
#Vote 'No'
kyved tx gov vote 1 no --from wallet --chain-id kyve-1 --gas-adjustment 1.4 --gas auto --gas-prices 2ukyve -y
#Vote 'Abstain'
kyved tx gov vote 1 abstain --from wallet --chain-id kyve-1 --gas-adjustment 1.4 --gas auto --gas-prices 2ukyve -y
#Vote 'NoWithVeto'
kyved tx gov vote 1 NoWithVeto --from wallet --chain-id kyve-1 --gas-adjustment 1.4 --gas auto --gas-prices 2ukyve -y
#โก๏ธ Utility
#Update ports
CUSTOM_PORT=110
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/.kyved/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/.kyved/config/app.toml
#Update Indexer
Disable indexer
sed -i -e 's|^indexer *=.*|indexer = "null"|' $HOME/.kyved/config/config.toml
Enable indexer
sed -i -e 's|^indexer *=.*|indexer = "kv"|' $HOME/.kyved/config/config.toml
#Update pruning
sed -i \
-e 's|^pruning *=.*|pruning = "custom"|' \
-e 's|^pruning-keep-recent *=.*|pruning-keep-recent = "107"|' \
-e 's|^pruning-keep-every *=.*|pruning-keep-every = "0"|' \
-e 's|^pruning-interval *=.*|pruning-interval = "13"|' \
$HOME/.kyved/config/app.toml
#๐จ Maintenance
#Get validator info
kyved status 2>&1 | jq .ValidatorInfo
#Get sync info
kyved status 2>&1 | jq .SyncInfo
#Get node peer
echo $(kyved tendermint show-node-id)'@'$(curl -s ifconfig.me)':'$(cat $HOME/.kyved/config/config.toml | sed -n '/Address to listen for incoming connection/{n;p;}' | sed 's/.*://; s/".*//')
#Check if validator key is correct
[[ $(kyved q staking validator $(kyved keys show wallet --bech val -a) -oj | jq -r .consensus_pubkey.key) = $(kyved 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:11057/net_info | jq -r '.result.peers[] | "\(.node_info.id)@\(.remote_ip):\(.node_info.listen_addr)"' | awk -F ':' '{print $1":"$(NF)}'
#Set minimum gas price
sed -i -e "s/^minimum-gas-prices *=.*/minimum-gas-prices = \"2ukyve\"/" $HOME/.kyved/config/app.toml
#Enable prometheus
sed -i -e "s/prometheus = false/prometheus = true/" $HOME/.kyved/config/config.toml
#Reset chain data
kyved tendermint unsafe-reset-all --home $HOME/.kyved --keep-addr-book
#Remove node
โ ย ย ย
Please, before proceeding with the next step! All chain data will be lost! Make sure you have backed up your **priv_validator_key.json**!
cd $HOME
sudo systemctl stop kyved
sudo systemctl disable kyved
sudo rm /etc/systemd/system/kyved.service
sudo systemctl daemon-reload
rm -f $(which kyved)
rm -rf $HOME/.kyved
rm -rf $HOME/kyved
#โ๏ธ Service Management
#Reload kyved configuration
sudo systemctl daemon-reload
#Enable kyved
sudo systemctl enable kyved
#Disable kyved
sudo systemctl disable kyved
#Start kyved
sudo systemctl start kyved
#Stop kyved
sudo systemctl stop kyved
#Restart kyved
sudo systemctl restart kyved
#Check kyved status
sudo systemctl status kyved
#Check kyved logs
sudo journalctl -u kyved -f --no-hostname -o cat
Chain ID:
The unique identifier for the blockchain network.
kyve-1
Latest Version:
The latest version of the chain software.
v1.5.0
Github:
The Github repository hosting the code for the network in question.
Public endpoints
Public endpoints are rate limited but can be used for basic CLI usage, node syncing or testing environments. Request an API key for enhanced access limits, we offer free trial periods of 14 days and cheap shared access plans from $50 a month.
REST/LCD
REST endpoint for querying blockchain data through the REST framework. Often available for Cosmos chains but also the main framework for Aleo as an example.
rest.lavenderfive.com:443/kyve
RPC
Remote Procedure Call endpoint for the consensus client of a blockchain. This is not an EVM endpoint (we call this json RPC) but the main framework for blockchain frameworks like Cosmos, Aptos, Sui and Near.
rpc.lavenderfive.com:443/kyve
gRPC
High-performance RPC endpoint for blockchain communication using the Google gRPC framework. This is often standard gRPC and not the "WEB" framework which is sometimes also accesible.
kyve.lavenderfive.com:443
WebSocket
WebSocket endpoint for real-time blockchain updates of the consensus client. This is not the EVM websocket integration, we name and expose that separately. WS is commonly available for Cosmos and Move networks that also expose a REST endpoint.
wss://rpc.lavenderfive.com:443/kyve/websocket
ยฉ 2022 Lavender.Five Nodes. All rights reserved.