Kyve Network

Delegate to us
Chain-ID: kyve-1
Latest Node Version: v1.4.0
Latest Block Height:

KYVE Network is revolutionizing customized access to on- and off-chain data by providing fast and easy tooling for decentralized data validation, immutability, and retrieval. The KYVE Network Stack, currently consisting of the KYVE Data Lake and Data Pipeline, enables all to securely store, validate, and query on and off-chain valid data in a streamlined manner. In the end, providing trustless data for a fast, secure, and scalable build.


Binary: realio-networkd
Denom: ario
Symbol: RIO
Exponent: 18
Folder Chain: .realio-network
Key management
kyved keys add kyved keys add  --recoverkyved keys listkyved keys delete kyved keys export kyved keys import  .backup
Check balance
kyved q bank balances $(kyved keys show  -a)
Service
sudo journalctl -u kyved -f --no-hostname -o catsudo systemctl start kyvedsudo systemctl stop kyvedsudo systemctl restart kyvedsudo systemctl status kyvedsudo systemctl daemon-reloadsudo systemctl enable kyvedsudo systemctl disable kyvedkyved status 2>&1 | jq .SyncInfoecho $(kyved tendermint show-node-id)'@'$(curl -s ifconfig.me)':'$(cat $HOME/.kyve/config/config.toml | sed -n '/Address to listen for incoming connection/{n;p;}' | sed 's/.*://; s/".*//')curl -sS http://localhost:657/net_info | jq -r '.result.peers[] | "\(.node_info.id)@\(.remote_ip):\(.node_info.listen_addr)"' | awk -F ':' '{print $1":"$(NF)}'
Validator management















Create Validator
kyved tx staking create-validator \
--amount=000000ukyve \
--moniker="" \
--pubkey=$(kyved tendermint show-validator) \
--identity="" \
--details="" \
--website="" \
--security-contact= \
--chain-id=kyve-1 \
--commission-rate=0. \
--commission-max-rate=0.20 \
--commission-max-change-rate=0. \
--min-self-delegation=1 \
--from= \
--gas-adjustment="1.4" \
--fees="5000ukyve"
Edit Validator
kyved tx staking edit-validator \
--new-moniker="" \
--chain-id=kyve-1 \
--from= \
--gas-adjustment="1.4" \
--fees="5000ukyve" -y
kyved tx staking edit-validator \
--identity="" \
--chain-id=kyve-1 \
--from= \
--gas-adjustment="1.4" \
--fees="5000ukyve"
kyved tx staking edit-validator \
--details="" \
--chain-id=kyve-1 \
--from= \
--gas-adjustment="1.4" \
--fees="5000ukyve"
kyved tx staking edit-validator \
--commission-rate=0. \
--chain-id=kyve-1 \
--from= \
--gas-adjustment="1.4" \
--fees="5000ukyve"
kyved tx staking edit-validator \
--new-moniker="" \
--identity="" \
--chain-id=kyve-1 \
--from= \
--gas-adjustment="1.4" \
--fees="5000ukyve"
kyved tx staking edit-validator \
--new-moniker="" \
--details="" \
--chain-id=kyve-1 \
--from= \
--gas-adjustment="1.4" \
--fees="5000ukyve"
kyved tx staking edit-validator \
--new-moniker="" \
--commission-rate=0. \
--chain-id=kyve-1 \
--from= \
--gas-adjustment="1.4" \
--fees="5000ukyve"
kyved tx staking edit-validator \
--identity="" \
--details="" \
--chain-id=kyve-1 \
--from= \
--gas-adjustment="1.4" \
--fees="5000ukyve"
kyved tx staking edit-validator \
--identity="" \
--commission-rate=0. \
--chain-id=kyve-1 \
--from= \
--gas-adjustment="1.4" \
--fees="5000ukyve"
kyved tx staking edit-validator \
--details="" \
--commission-rate=0. \
--chain-id=kyve-1 \
--from= \
--gas-adjustment="1.4" \
--fees="5000ukyve"
kyved tx staking edit-validator \
--new-moniker="" \
--identity="" \
--details="" \
--chain-id=kyve-1 \
--from= \
--gas-adjustment="1.4" \
--fees="5000ukyve"
kyved tx staking edit-validator \
--new-moniker="" \
--identity="" \
--commission-rate=0. \
--chain-id=kyve-1 \
--from= \
--gas-adjustment="1.4" \
--fees="5000ukyve"
kyved tx staking edit-validator \
--new-moniker="" \
--details="" \
--commission-rate=0. \
--chain-id=kyve-1 \
--from= \
--gas-adjustment="1.4" \
--fees="5000ukyve"
kyved tx staking edit-validator \
--identity="" \
--details="" \
--commission-rate=0. \
--chain-id=kyve-1 \
--from= \
--gas-adjustment="1.4" \
--fees="5000ukyve"
kyved tx staking edit-validator \
--new-moniker="" \
--identity="" \
--details="" \
--commission-rate=0. \
--chain-id=kyve-1 \
--from= \
--gas-adjustment="1.4" \
--fees="5000ukyve"
kyved tx staking edit-validator \
--new-moniker="" \
--identity="" \
--details="" \
--website="" \
--security-contact= \
--chain-id=kyve-1 \
--commission-rate=0. \
--from= \
--gas-adjustment="1.4" \
--fees="5000ukyve"




kyved status 2>&1 | jq .ValidatorInfokyved q staking validator $(kyved keys show  --bech val -a)kyved q slashing signing-info $(kyved tendermint show-validator)kyved tx slashing unjail --broadcast-mode=block --from  --chain-id kyve-1 --gas-adjustment="1.4" --fees="5000ukyve"kyved q staking validators -oj --limit=2000 | jq '.validators[] | select(.status=="BOND_STATUS_BONDED")' | jq -r '(.tokens|tonumber/pow(10; 6)|floor|tostring) + " 	 " + .description.moniker' | sort -gr | nl[[ $(kyved q staking validator $(kyved keys show  --bech val -a) -oj | jq -r .consensus_pubkey.key) = $(kyved status | jq -r .ValidatorInfo.PubKey.value) ]] && echo -e "Your key status is ok" || echo -e "Your key status is error"kyved q slashing signing-info $(kyved tendermint show-validator)
Token management
kyved tx distribution withdraw-all-rewards --from  --chain-id kyve-1 --gas-adjustment="1.4" --fees="5000ukyve"kyved tx distribution withdraw-rewards $(kyved keys show  --bech val -a) --commission --from  --chain-id kyve-1 --gas-adjustment="1.4" --fees="5000ukyve"kyved tx staking delegate $(kyved keys show  --bech val -a) 000000ukyve --from  --chain-id kyve-1 --gas-adjustment="1.4" --fees="5000ukyve"kyved tx staking redelegate $(kyved keys show  --bech val -a)  000000ukyve --from  --chain-id kyve-1 --gas-adjustment="1.4" --fees="5000ukyve"kyved tx staking delegate  000000ukyve --from  --chain-id kyve-1 --gas-adjustment="1.4" --fees="5000ukyve"kyved tx staking unbond $(kyved keys show  --bech val -a) 000000ukyve --from  --chain-id kyve-1 --gas-adjustment="1.4" --fees="5000ukyve"kyved tx bank send   000000ukyve --from  --chain-id kyve-1 --gas-adjustment="1.4" --fees="5000ukyve"
Governance
View Proposal
kyved query gov proposal 
Vote
kyved tx gov vote   --from  --chain-id kyve-1 --gas-adjustment="1.4" --fees="5000ukyve"
Utility
Set Custom Port




CUSTOM_PORT=
sed -i.bak -e "s%^proxy_app = \"tcp://127.0.0.1:26658\"%proxy_app = \"tcp://127.0.0.1:${CUSTOM_PORT}658\"%; s%^laddr = \"tcp://127.0.0.1:26657\"%laddr = \"tcp://127.0.0.1:${CUSTOM_PORT}657\"%; s%^pprof_laddr = \"localhost:6060\"%pprof_laddr = \"localhost:${CUSTOM_PORT}060\"%; s%^laddr = \"tcp://0.0.0.0:26656\"%laddr = \"tcp://0.0.0.0:${CUSTOM_PORT}656\"%; s%^prometheus_listen_addr = \":26660\"%prometheus_listen_addr = \":${CUSTOM_PORT}660\"%" $HOME/.kyve/config/config.toml
sed -i.bak -e "s%^address = \"tcp://0.0.0.0:1317\"%address = \"tcp://0.0.0.0:${CUSTOM_PORT}317\"%; s%^address = \":8080\"%address = \":${CUSTOM_PORT}080\"%; s%^address = \"0.0.0.0:9090\"%address = \"0.0.0.0:${CUSTOM_PORT}090\"%; s%^address = \"0.0.0.0:9091\"%address = \"0.0.0.0:${CUSTOM_PORT}091\"%; s%^address = \"127.0.0.1:8545\"%address = \"0.0.0.0:${CUSTOM_PORT}545\"%; s%^ws-address = \"127.0.0.1:8546\"%ws-address = \"0.0.0.0:${CUSTOM_PORT}546\"%" $HOME/.kyve/config/app.toml
Enable Indexing usually enabled by default
sed -i -e 's|^indexer *=.*|indexer = "kv"|' $HOME/.kyve/config/config.toml
Disable Indexing
sed -i -e 's|^indexer *=.*|indexer = "null"|' $HOME/.kyve/config/config.toml
Reset Chain Data
kyved tendermint unsafe-reset-all --home $HOME/.kyve --keep-addr-book
Delete Node
WARNING! This action will remove all files related to the kyved chain! Make sure you have backed up your priv_validator_key.json
sudo systemctl stop kyved && \
sudo systemctl disable kyved && \
rm /etc/systemd/system/kyved.service && \
sudo systemctl daemon-reload && \
cd $HOME && \
rm -rf .kyve && \
rm -rf $(which kyved)
Genesis
wget -O $HOME/.kyve/config/genesis.json "https://files.kyve.network/mainnet/genesis.json"
Addrbook
Update every 1h
wget -O $HOME/.kyve/config/addrbook.json "https://raw.githubusercontent.com/kynraze/service/main/mainnet/kyve/addrbook.json"
List Peers:
PEERS= 
sed -i -e "s|^persistent_peers *=.*|persistent_peers = "$PEERS"|" $HOME/.kyve/config/config.toml
In case our endpoint experiences an issue, we use the Cosmos directory endpoint as a backup.
Api Endpoint
RPC Endpoint
gRPC Endpoint
Auto Installation
Script Info
Binary
:
FOLDER
:
Golang Version
:
Snapshot
:
From Stratch ||
wget -O auto-kyve.sh https://raw.githubusercontent.com/kynraze/service/main/mainnet/kyve/install-auto.sh && chmod +x auto-kyve.sh && ./auto-kyve.sh
With StateSync
With Snapshot ||
Manual Installation
Setting vars




KYVE_NODENAME=""

save and import variable

echo "export KYVE_NODENAME=$KYVE_NODENAME" >> $HOME/.bash_profile if [ ! $WALLET ]; then echo "export WALLET=wallet" >> $HOME/.bash_profile fi echo "export KYVE_CHAIN_ID=kyve-1" >> $HOME/.bash_profile source $HOME/.bash_profile

Install and update dependencies

sudo apt update && sudo apt upgrade -y && sudo apt install curl tar wget clang pkg-config libssl-dev jq build-essential bsdmainutils git make ncdu gcc git jq chrony liblz4-tool -y

Install Go

ver="1.20" cd $HOME wget "https://golang.org/dl/go$ver.linux-amd64.tar.gz" sudo rm -rf /usr/local/go sudo tar -C /usr/local -xzf "go$ver.linux-amd64.tar.gz" rm "go$ver.linux-amd64.tar.gz" echo "export PATH=$PATH:/usr/local/go/bin:$HOME/go/bin" >> ~/.bash_profile source ~/.bash_profile

Check golang

go version

Install app

git clone https://github.com/KYVENetwork/chain.git cd chain git checkout v1.4.0 make install

Verify that Binary successfully installed

kyved version --long

Custom Port (Optional)




CUSTOM_PORT= sed -i.bak -e "s%^proxy_app = \"tcp://127.0.0.1:26658\"%proxy_app = \"tcp://127.0.0.1:${CUSTOM_PORT}658\"%; s%^laddr = \"tcp://127.0.0.1:26657\"%laddr = \"tcp://127.0.0.1:${CUSTOM_PORT}657\"%; s%^pprof_laddr = \"localhost:6060\"%pprof_laddr = \"localhost:${CUSTOM_PORT}060\"%; s%^laddr = \"tcp://0.0.0.0:26656\"%laddr = \"tcp://0.0.0.0:${CUSTOM_PORT}656\"%; s%^prometheus_listen_addr = \":26660\"%prometheus_listen_addr = \":${CUSTOM_PORT}660\"%" $HOME/.kyve/config/config.toml sed -i.bak -e "s%^address = \"tcp://0.0.0.0:1317\"%address = \"tcp://0.0.0.0:${CUSTOM_PORT}317\"%; s%^address = \":8080\"%address = \":${CUSTOM_PORT}080\"%; s%^address = \"0.0.0.0:9090\"%address = \"0.0.0.0:${CUSTOM_PORT}090\"%; s%^address = \"0.0.0.0:9091\"%address = \"0.0.0.0:${CUSTOM_PORT}091\"%; s%^address = \"127.0.0.1:8545\"%address = \"0.0.0.0:${CUSTOM_PORT}545\"%; s%^ws-address = \"127.0.0.1:8546\"%ws-address = \"0.0.0.0:${CUSTOM_PORT}546\"%" $HOME/.kyve/config/app.toml

Config App

kyved config chain-id $KYVE_CHAIN_ID kyved config keyring-backend file kyved config node tcp://localhost:657

Initialize

kyved init $KYVE_NODENAME --chain-id $KYVE_CHAIN_ID

Get Genesis and Addrbook
Download genesis
wget -O $HOME/.kyve/config/genesis.json "https://files.kyve.network/mainnet/genesis.json"
Download Addrbook
wget -O $HOME/.kyve/config/addrbook.json "https://raw.githubusercontent.com/kynraze/service/main/mainnet/kyve/addrbook.json"
Set Seeds and Peers

PEERS="" sed -i.bak -e "s/^persistent_peers *=.*/persistent_peers = \"$PEERS\"/" $HOME/.kyve/config/config.toml sed -i -e "s|^seeds *=.*|seeds = \"\"|" $HOME/.kyve/config/config.toml

Config pruning

pruning="custom" pruning_keep_recent="100" pruning_keep_every="0" pruning_interval="10" sed -i -e "s/^pruning *=.*/pruning = \"$pruning\"/" $HOME/.kyve/config/app.toml sed -i -e "s/^pruning-keep-recent *=.*/pruning-keep-recent = \"$pruning_keep_recent\"/" $HOME/.kyve/config/app.toml sed -i -e "s/^pruning-keep-every *=.*/pruning-keep-every = \"$pruning_keep_every\"/" $HOME/.kyve/config/app.toml sed -i -e "s/^pruning-interval *=.*/pruning-interval = \"$pruning_interval\"/" $HOME/.kyve/config/app.toml

Create service file and start node
Create Service

sudo tee /etc/systemd/system/kyved.service > /dev/null << EOF [Unit] Description=kyved After=network-online.target

[Service] User=$USER ExecStart=$(which kyved) start --home $HOME/.kyve Restart=on-failure RestartSec=3 LimitNOFILE=65535

[Install] WantedBy=multi-user.target EOF

Download Snapshot (Optional)

curl -o - -L https://snap.kynraze.com/kyve/snapshot-latest.tar.lz4 | lz4 -c -d - | tar -x -C $HOME/.kyve

Start Service

sudo systemctl daemon-reload sudo systemctl enable kyved sudo systemctl restart kyved sudo journalctl -fu kyved -o cat

Snapshots are taken automatically every 6 hours
Snapshot Info
Block Height
:
Size
:
Block Time
:
Indexer
:
Pruning
:
pruning-keep-recent
:
pruning-keep-every
: 0
pruning-interval
:
Currently, we do not provide snapshots
Instruction
# Update & install lz4(Required)
sudo apt install snapd lz4 -y

# Reset Chain Data
sed -i.bak -E "s|^(enable[[:space:]]+=[[:space:]]+).*$|\1false|" $HOME/.kyve/config/config.toml
sudo systemctl stop kyved
cp $HOME/.kyve/data/priv_validator_state.json $HOME/.kyve/priv_validator_state.json.backup
rm -rf $HOME/.kyve/data

# Download Data Snapshot
curl -o - -L https://snap.kynraze.com/kyve/snapshot-latest.tar.lz4 | lz4 -c -d - | tar -x -C $HOME/.kyve
mv $HOME/.kyve/priv_validator_state.json.backup $HOME/.kyve/data/priv_validator_state.json

# Restart
sudo systemctl restart kyved
sudo journalctl -fu kyved -o cat
About State Sync
With fast sync a node is downloading all of the data of an application from genesis and verifying it. With state sync your node will download data related to the head or near the head of the chain and verify the data. This leads to drastically shorter times for joining a network.
State Sync Configuration
Pruning
:
pruning-keep-recent
:
pruning-keep-every
: 0
pruning-interval
:
Instruction
systemctl stop kyved
kyved tendermint unsafe-reset-all --home $HOME/.kyve --keep-addr-book

STATE_SYNC_RPC=""

LATEST_HEIGHT=$(curl -s $STATE_SYNC_RPC/block | jq -r .result.block.header.height) \
SYNC_BLOCK_HEIGHT=$(($LATEST_HEIGHT - 2000)) \
SYNC_BLOCK_HASH=$(curl -s "$STATE_SYNC_RPC/block?height=$SYNC_BLOCK_HEIGHT" | jq -r .result.block_id.hash)
echo $LATEST_HEIGHT $SYNC_BLOCK_HEIGHT $SYNC_BLOCK_HASH

PEERS=""
sed -i.bak -e "s/^persistent_peers *=.*/persistent_peers = \"$PEERS\"/" $HOME/.kyve/config/config.toml

sed -i.bak -e "s|^enable *=.*|enable = true|" $HOME/.kyve/config/config.toml
sed -i.bak -e "s|^rpc_servers *=.*|rpc_servers = \"$STATE_SYNC_RPC,$STATE_SYNC_RPC\"|" \
$HOME/.kyve/config/config.toml
sed -i.bak -e "s|^trust_height *=.*|trust_height = $SYNC_BLOCK_HEIGHT|" \
$HOME/.kyve/config/config.toml
sed -i.bak -e "s|^trust_hash *=.*|trust_hash = \"$SYNC_BLOCK_HASH\"|" \
$HOME/.kyve/config/config.toml

systemctl restart kyved && journalctl -fu kyved -o cat