Router

Explorer
Chain-ID:
Latest Node Version:
Latest Block Height:

Route is a transferable representation of a functional asset that will be used as the gas and governance token in the router ecosystem.‚Äč


Binary: realio-networkd
Denom: ario
Symbol: RIO
Exponent: 18
Folder Chain: .realio-network
Key management
routerd keys add routerd keys add  --recoverrouterd keys listrouterd keys delete routerd keys export routerd keys import  .backup
Check balance
routerd q bank balances $(routerd keys show  -a)
Service
sudo journalctl -u routerd -f --no-hostname -o catsudo systemctl start routerdsudo systemctl stop routerdsudo systemctl restart routerdsudo systemctl status routerdsudo systemctl daemon-reloadsudo systemctl enable routerdsudo systemctl disable routerdrouterd status 2>&1 | jq .SyncInfoecho $(routerd tendermint show-node-id)'@'$(curl -s ifconfig.me)':'$(cat $HOME/.routerd/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
routerd tx staking create-validator \
--amount=000000000000000000route \
--moniker="" \
--pubkey=$(routerd tendermint show-validator) \
--identity="" \
--details="" \
--website="" \
--security-contact= \
--chain-id= \
--commission-rate=0. \
--commission-max-rate=0.20 \
--commission-max-change-rate=0. \
--min-self-delegation=1 \
--from= \
--gas="1000000" \
--gas-prices="30000000000route"
Edit Validator
routerd tx staking edit-validator \
--new-moniker="" \
--chain-id= \
--from= \
--gas="1000000" \
--gas-prices="30000000000route" -y
routerd tx staking edit-validator \
--identity="" \
--chain-id= \
--from= \
--gas="1000000" \
--gas-prices="30000000000route"
routerd tx staking edit-validator \
--details="" \
--chain-id= \
--from= \
--gas="1000000" \
--gas-prices="30000000000route"
routerd tx staking edit-validator \
--commission-rate=0. \
--chain-id= \
--from= \
--gas="1000000" \
--gas-prices="30000000000route"
routerd tx staking edit-validator \
--new-moniker="" \
--identity="" \
--chain-id= \
--from= \
--gas="1000000" \
--gas-prices="30000000000route"
routerd tx staking edit-validator \
--new-moniker="" \
--details="" \
--chain-id= \
--from= \
--gas="1000000" \
--gas-prices="30000000000route"
routerd tx staking edit-validator \
--new-moniker="" \
--commission-rate=0. \
--chain-id= \
--from= \
--gas="1000000" \
--gas-prices="30000000000route"
routerd tx staking edit-validator \
--identity="" \
--details="" \
--chain-id= \
--from= \
--gas="1000000" \
--gas-prices="30000000000route"
routerd tx staking edit-validator \
--identity="" \
--commission-rate=0. \
--chain-id= \
--from= \
--gas="1000000" \
--gas-prices="30000000000route"
routerd tx staking edit-validator \
--details="" \
--commission-rate=0. \
--chain-id= \
--from= \
--gas="1000000" \
--gas-prices="30000000000route"
routerd tx staking edit-validator \
--new-moniker="" \
--identity="" \
--details="" \
--chain-id= \
--from= \
--gas="1000000" \
--gas-prices="30000000000route"
routerd tx staking edit-validator \
--new-moniker="" \
--identity="" \
--commission-rate=0. \
--chain-id= \
--from= \
--gas="1000000" \
--gas-prices="30000000000route"
routerd tx staking edit-validator \
--new-moniker="" \
--details="" \
--commission-rate=0. \
--chain-id= \
--from= \
--gas="1000000" \
--gas-prices="30000000000route"
routerd tx staking edit-validator \
--identity="" \
--details="" \
--commission-rate=0. \
--chain-id= \
--from= \
--gas="1000000" \
--gas-prices="30000000000route"
routerd tx staking edit-validator \
--new-moniker="" \
--identity="" \
--details="" \
--commission-rate=0. \
--chain-id= \
--from= \
--gas="1000000" \
--gas-prices="30000000000route"
routerd tx staking edit-validator \
--new-moniker="" \
--identity="" \
--details="" \
--website="" \
--security-contact= \
--chain-id= \
--commission-rate=0. \
--from= \
--gas="1000000" \
--gas-prices="30000000000route"




routerd status 2>&1 | jq .ValidatorInforouterd q staking validator $(routerd keys show  --bech val -a)routerd q slashing signing-info $(routerd tendermint show-validator)routerd tx slashing unjail --broadcast-mode=block --from  --chain-id  --gas="1000000" --gas-prices="30000000000route"routerd 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[[ $(routerd q staking validator $(routerd keys show  --bech val -a) -oj | jq -r .consensus_pubkey.key) = $(routerd status | jq -r .ValidatorInfo.PubKey.value) ]] && echo -e "Your key status is ok" || echo -e "Your key status is error"routerd q slashing signing-info $(routerd tendermint show-validator)
Token management
routerd tx distribution withdraw-all-rewards --from  --chain-id  --gas="1000000" --gas-prices="30000000000route"routerd tx distribution withdraw-rewards $(routerd keys show  --bech val -a) --commission --from  --chain-id  --gas="1000000" --gas-prices="30000000000route"routerd tx staking delegate $(routerd keys show  --bech val -a) 000000000000000000route --from  --chain-id  --gas="1000000" --gas-prices="30000000000route"routerd tx staking redelegate $(routerd keys show  --bech val -a)  000000000000000000route --from  --chain-id  --gas="1000000" --gas-prices="30000000000route"routerd tx staking delegate  000000000000000000route --from  --chain-id  --gas="1000000" --gas-prices="30000000000route"routerd tx staking unbond $(routerd keys show  --bech val -a) 000000000000000000route --from  --chain-id  --gas="1000000" --gas-prices="30000000000route"routerd tx bank send   000000000000000000route --from  --chain-id  --gas="1000000" --gas-prices="30000000000route"
Governance
View Proposal
routerd query gov proposal 
Vote
routerd tx gov vote   --from  --chain-id  --gas="1000000" --gas-prices="30000000000route"
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/.routerd/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/.routerd/config/app.toml
Enable Indexing usually enabled by default
sed -i -e 's|^indexer *=.*|indexer = "kv"|' $HOME/.routerd/config/config.toml
Disable Indexing
sed -i -e 's|^indexer *=.*|indexer = "null"|' $HOME/.routerd/config/config.toml
Reset Chain Data
routerd tendermint unsafe-reset-all --home $HOME/.routerd --keep-addr-book
Delete Node
WARNING! This action will remove all files related to the routerd chain! Make sure you have backed up your priv_validator_key.json
sudo systemctl stop routerd && \
sudo systemctl disable routerd && \
rm /etc/systemd/system/routerd.service && \
sudo systemctl daemon-reload && \
cd $HOME && \
rm -rf .routerd && \
rm -rf $(which routerd)
Genesis
wget -O $HOME/.routerd/config/genesis.json "https://raw.githubusercontent.com/kynraze/service/main/testnet/router/genesis.json"
Addrbook
Update every 1h
wget -O $HOME/.routerd/config/addrbook.json "https://snap.kynraze.com/test/router/addrbook.json"
List Peers:
PEERS= 
sed -i -e "s|^persistent_peers *=.*|persistent_peers = "$PEERS"|" $HOME/.routerd/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 ||
Coming Soon
With StateSync
With Snapshot ||
Manual Installation
Setting vars




ROUTER_NODENAME=""

save and import variable

echo "export ROUTER_NODENAME=$ROUTER_NODENAME" >> $HOME/.bash_profile if [ ! $WALLET ]; then echo "export WALLET=wallet" >> $HOME/.bash_profile fi echo "export ROUTER_CHAIN_ID=" >> $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

wget https://snap.kynraze.com/test/router/routerd chmod +x routerd mv routerd $HOME/go/bin/

Verify that Binary successfully installed

routerd 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/.routerd/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/.routerd/config/app.toml

Config App

routerd config chain-id $ROUTER_CHAIN_ID routerd config keyring-backend file routerd config node tcp://localhost:657

Initialize

routerd init $ROUTER_NODENAME --chain-id $ROUTER_CHAIN_ID

Get Genesis and Addrbook
Download genesis
wget -O $HOME/.routerd/config/genesis.json "https://raw.githubusercontent.com/kynraze/service/main/testnet/router/genesis.json"
Download Addrbook
wget -O $HOME/.routerd/config/addrbook.json "https://snap.kynraze.com/test/router/addrbook.json"
Set Seeds and Peers

PEERS="" sed -i.bak -e "s/^persistent_peers *=.*/persistent_peers = \"$PEERS\"/" $HOME/.routerd/config/config.toml sed -i -e "s|^seeds *=.*|seeds = \"\"|" $HOME/.routerd/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/.routerd/config/app.toml sed -i -e "s/^pruning-keep-recent *=.*/pruning-keep-recent = \"$pruning_keep_recent\"/" $HOME/.routerd/config/app.toml sed -i -e "s/^pruning-keep-every *=.*/pruning-keep-every = \"$pruning_keep_every\"/" $HOME/.routerd/config/app.toml sed -i -e "s/^pruning-interval *=.*/pruning-interval = \"$pruning_interval\"/" $HOME/.routerd/config/app.toml

Create service file and start node
Create Service

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

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

[Install] WantedBy=multi-user.target EOF

Download Snapshot (Optional)

curl -o - -L | lz4 -c -d - | tar -x -C $HOME/.routerd

Start Service

sudo systemctl daemon-reload sudo systemctl enable routerd sudo systemctl restart routerd sudo journalctl -fu routerd -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/.routerd/config/config.toml
sudo systemctl stop routerd
cp $HOME/.routerd/data/priv_validator_state.json $HOME/.routerd/priv_validator_state.json.backup
rm -rf $HOME/.routerd/data

# Download Data Snapshot
curl -o - -L | lz4 -c -d - | tar -x -C $HOME/.routerd
mv $HOME/.routerd/priv_validator_state.json.backup $HOME/.routerd/data/priv_validator_state.json

# Restart
sudo systemctl restart routerd
sudo journalctl -fu routerd -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 routerd
routerd tendermint unsafe-reset-all --home $HOME/.routerd --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/.routerd/config/config.toml

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

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