AtomOne

Delegate to us
Chain-ID: atomone-1
Latest Node Version: v2.0.0
Latest Block Height:

AtomOne is a branch of Gaia that complements the broader Cosmos ecosystem with a security-conscious alternative hub. AtomOne recommits to the founding vision of the Cosmos Hub as a minimal IBC/ICS hub secured by a staking token targeting two-thirds of the stake bonded. AtomOne contributors uphold the original values of the Cosmos Hub—security, sustainability, decentralization—and agree that hub minimalism enforced by a written constitution is the only way to ensure financial security and scale to billions of people.


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




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




ATOMONE_NODENAME=""

save and import variable

echo "export ATOMONE_NODENAME=$ATOMONE_NODENAME" >> $HOME/.bash_profile if [ ! $WALLET ]; then echo "export WALLET=wallet" >> $HOME/.bash_profile fi echo "export ATOMONE_CHAIN_ID=atomone-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.21.2" 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/atomone-hub/atomone.git cd atomone git checkout v2.0.0 make install

Verify that Binary successfully installed

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

Config App

atomoned config chain-id $ATOMONE_CHAIN_ID atomoned config keyring-backend file atomoned config node tcp://localhost:657

Initialize

atomoned init $ATOMONE_NODENAME --chain-id $ATOMONE_CHAIN_ID

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

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

Create service file and start node
Create Service

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

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

[Install] WantedBy=multi-user.target EOF

Download Snapshot (Optional)

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

Start Service

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

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

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

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

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