Union Validator Tools & Infrastructure Documentation
Complete infrastructure toolkit for Union validators and developers. Access our professional-grade services including RPC nodes, API endpoints, daily snapshots, and real-time metrics. Our union 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.
Setting up your validator node has never been so easy. Get your validator running in minutes by following step by step instructions.
#Setup validator name
ⓘ   
Replace **YOUR_MONIKER_GOES_HERE** with your validator name
MONIKER="YOUR_MONIKER_GOES_HERE"
#Install dependencies
#Update system and install build tools
sudo apt -q update
sudo apt -qy install curl git jq lz4 build-essential
sudo apt -qy upgrade
#Install Go
sudo rm -rf /usr/local/go
curl -Ls https://go.dev/dl/go1.19.8.linux-amd64.tar.gz | sudo tar -xzf - -C /usr/local
eval $(echo 'export PATH=$PATH:/usr/local/go/bin' | sudo tee /etc/profile.d/golang.sh)
eval $(echo 'export PATH=$PATH:$HOME/go/bin' | tee -a $HOME/.profile)
#Download and build binaries
# Clone project repository
cd $HOME
rm -rf union
git clone https://github.com/unionlabs/union union
cd union
git checkout uniond%2Fv1.0.0-rc3.alpha1
# Build binaries
make install
# Prepare binaries for Cosmovisor
mkdir -p $HOME/.uniond/cosmovisor/genesis/bin
mv ~/go/bin/uniond $HOME/.uniond/cosmovisor/genesis/bin/
rm -rf build
#Install Cosmovisor and create a service
# Download and install Cosmovisor
go install cosmossdk.io/tools/cosmovisor/cmd/[email protected]
# Create service
sudo tee /etc/systemd/system/uniond.service > /dev/null << EOF
[Unit]
Description=osmosis node service
After=network-online.target
[Service]
User=$USER
ExecStart=$(which cosmovisor) run start
WorkingDirectory=$HOME/.uniond
Restart=always
RestartSec=5
LimitNOFILE=65535
Environment="DAEMON_HOME=$HOME/.uniond"
Environment="DAEMON_NAME=uniond"
Environment="DAEMON_ALLOW_DOWNLOAD_BINARIES=false"
Environment="DAEMON_RESTART_AFTER_UPGRADE=true"
Environment="UNSAFE_SKIP_BACKUP=true"
Environment="PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:$HOME/.uniond/cosmovisor/current/bin"
[Install]
WantedBy=multi-user.target
EOF
sudo systemctl daemon-reload
sudo systemctl enable uniond
#Initialize the node
# Set node configuration
uniond config chain-id union-testnet-10
uniond config node tcp://localhost:{{ custom_port_prefix }}57
# Initialize the node
uniond init $MONIKER --chain-id union-testnet-10
# Download genesis and addrbook
curl -Ls https://raw.githubusercontent.com/unionlabs/union/refs/heads/main/networks/genesis/union-testnet-10/genesis.json > $HOME/.uniond/config/genesis.json
curl -Ls https://snapshots.lavenderfive.com/testnet-snapshots/union/addrbook.json > $HOME/.uniond/config/addrbook.json
# Add seeds
seeds="[email protected]:26656"
sed -i -e "s|^seeds *=.*|seeds = \"$seeds\"|" $HOME/.uniond/config/config.toml
# Set minimum gas price
sed -i -e "s|^minimum-gas-prices *=.*|minimum-gas-prices = \"0umuno\"|" $HOME/.uniond/config/app.toml
# Set pruning
sed -i \
  -e 's|^pruning *=.*|pruning = "custom"|' \
  -e 's|^pruning-keep-recent *=.*|pruning-keep-recent = "100"|' \
  -e 's|^pruning-keep-every *=.*|pruning-keep-every = "0"|' \
  -e 's|^pruning-interval *=.*|pruning-interval = "19"|' \
  $HOME/.uniond/config/app.toml
# Set custom ports
sed -i -e "s%^proxy_app = \"tcp://127.0.0.1:26658\"%proxy_app = \"tcp://127.0.0.1:{{ custom_port_prefix }}58\"%; s%^laddr = \"tcp://127.0.0.1:26657\"%laddr = \"tcp://127.0.0.1:{{ custom_port_prefix }}57\"%; s%^pprof_laddr = \"localhost:6060\"%pprof_laddr = \"localhost:{{ custom_port_prefix }}60\"%; s%^laddr = \"tcp://0.0.0.0:26656\"%laddr = \"tcp://0.0.0.0:{{ custom_port_prefix }}56\"%; s%^prometheus_listen_addr = \":26660\"%prometheus_listen_addr = \":{{ custom_port_prefix }}66\"%" $HOME/.uniond/config/config.toml
sed -i -e "s%^address = \"tcp://0.0.0.0:1317\"%address = \"tcp://0.0.0.0:{{ custom_port_prefix }}17\"%; s%^address = \":8080\"%address = \":{{ custom_port_prefix }}80\"%; s%^address = \"0.0.0.0:9090\"%address = \"0.0.0.0:{{ custom_port_prefix }}90\"%; s%^address = \"0.0.0.0:9091\"%address = \"0.0.0.0:{{ custom_port_prefix }}91\"%; s%:8545%:{{ custom_port_prefix }}45%; s%:8546%:{{ custom_port_prefix }}46%; s%:6065%:{{ custom_port_prefix }}65%" $HOME/.uniond/config/app.toml
#Start service and check the logs
sudo systemctl start uniond && sudo journalctl -u uniond -f --no-hostname -o cat
#Sync
To catch up quickly, you can either use a snapshot or state sync
Chain ID:
The unique identifier for the blockchain network.
union-testnet-10Latest Version:
The latest version of the chain software.
uniond%2Fv1.0.0-rc3.alpha1Github:
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.
testnet-rest.lavenderfive.com:443/union
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.
testnet-rpc.lavenderfive.com:443/union
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.
testnet-union.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://testnet-rpc.lavenderfive.com:443/union/websocket
© 2022 Lavender.Five Nodes. All rights reserved.












