SGE Network

Delegate to us
Chain-ID: sgenet-1
Latest Node Version: v1.3.1
Latest Block Height:

A Cosmos SDK-Based Layer-1 Blockchain Utilizing Its Own Native Utility Token (SGE Token). The SGE Network Leverages The Modular Components, Blockchain Interoperability And Minimal Gas Fees Of The Cosmos-Based Design To Support Applications At The Intersection Of Blockchain, Sports, Gaming And Entertainment That Are Pioneering Novel Ways Of Engaging Users With A UX, Value Proposition And Utility Never Before Seen In The Space.


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




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




SGE_NODENAME=""

save and import variable

echo "export SGE_NODENAME=$SGE_NODENAME" >> $HOME/.bash_profile if [ ! $WALLET ]; then echo "export WALLET=wallet" >> $HOME/.bash_profile fi echo "export SGE_CHAIN_ID=sgenet-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/sge-network/sge.git cd sge git checkout v1.3.1 make install

Verify that Binary successfully installed

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

Config App

sged config chain-id $SGE_CHAIN_ID sged config keyring-backend file sged config node tcp://localhost:657

Initialize

sged init $SGE_NODENAME --chain-id $SGE_CHAIN_ID

Get Genesis and Addrbook
Download genesis
wget -O $HOME/.sge/config/genesis.json "https://snap.kynraze.com/sge/genesis.json"
Download Addrbook
wget -O $HOME/.sge/config/addrbook.json "https://snap.kynraze.com/sge/addrbook.json"
Set Seeds and Peers

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

Create service file and start node
Create Service

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

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

[Install] WantedBy=multi-user.target EOF

Download Snapshot (Optional)

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

Start Service

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

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

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

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

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