installation
Last updated
Last updated
Network name: Cudos | Chain ID: cudos-1
| Latest version: v9.9.9
| Custom Port: 123
Replace YOUR_MONIKER_GOES_HERE with your validator name
MONIKER="YOUR_MONIKER_GOES_HERE"
Update system and install build tools
sudo apt -q update
sudo apt -qy install curl git jq zst 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)
# Clone project repository
cd $HOME
rm -rf cudos
git clone https://github.com/CudoVentures/cudos-node cudos
cd cudos
git checkout v9.9.9
# Build binaries
make install
# Prepare binaries for Cosmovisor
mkdir -p $HOME/cudos-data/cosmovisor/genesis/bin
mv ~/go/bin/cudos-noded $HOME/cudos-data/cosmovisor/genesis/bin/
rm -rf build
# Download and install Cosmovisor
go install cosmossdk.io/tools/cosmovisor/cmd/cosmovisor@v1.4.0
# Create service
sudo tee /etc/systemd/system/cudos-noded.service > /dev/null << EOF
[Unit]
Description=osmosis node service
After=network-online.target
[Service]
User=$USER
ExecStart=$(which cosmovisor) run start
WorkingDirectory=$HOME/cudos-data
Restart=always
RestartSec=5
LimitNOFILE=65535
Environment="DAEMON_HOME=$HOME/cudos-data"
Environment="DAEMON_NAME=cudos-noded"
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/cudos-data/cosmovisor/current/bin"
[Install]
WantedBy=multi-user.target
EOF
sudo systemctl daemon-reload
sudo systemctl enable cudos-noded
# Set node configuration
cudos-noded config chain-id cudos-1
cudos-noded config node tcp://localhost:12357
# Initialize the node
cudos-noded init $MONIKER --chain-id cudos-1
# Download genesis and addrbook
curl -Ls https://raw.githubusercontent.com/CudoVentures/cudos-builders/v1.0.0/docker/config/genesis.mainnet.json > $HOME/cudos-data/config/genesis.json
curl -Ls https://snapshots.lavenderfive.com/addrbooks/cudos/addrbook.json > $HOME/cudos-data/config/addrbook.json
# Add seeds
seeds="ff3f0f7b1eecc6844e6512428ef4c7a9448452a8@cluster-1-seed-1.hosts.cudos.org:26656,6d9beb4d44a530a4a10ebe78ed7717f6083d0c4b@cluster-2-seed-1.hosts.cudos.org:26656,e0f3bcc574ef66ae4561fad0772a4fd1959969af@cluster-3-seed-1.hosts.cudos.org:26656,ebc272824924ea1a27ea3183dd0b9ba713494f83@cudos-mainnet-seed.autostake.com:27256,20e1000e88125698264454a884812746c2eb4807@seeds.lavenderfive.com:12356,8542cd7e6bf9d260fef543bc49e59be5a3fa9074@seed.publicnode.com:26656"
sed -i -e "s|^seeds *=.*|seeds = \"$seeds\"|" $HOME/cudos-data/config/config.toml
# Set minimum gas price
sed -i -e "s|^minimum-gas-prices *=.*|minimum-gas-prices = \"0acudos\"|" $HOME/cudos-data/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/cudos-data/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:12358\"%; s%^laddr = \"tcp://127.0.0.1:26657\"%laddr = \"tcp://127.0.0.1:12357\"%; s%^pprof_laddr = \"localhost:6060\"%pprof_laddr = \"localhost:12360\"%; s%^laddr = \"tcp://0.0.0.0:26656\"%laddr = \"tcp://0.0.0.0:12356\"%; s%^prometheus_listen_addr = \":26660\"%prometheus_listen_addr = \":12366\"%" $HOME/cudos-data/config/config.toml
sed -i -e "s%^address = \"tcp://0.0.0.0:1317\"%address = \"tcp://0.0.0.0:12317\"%; s%^address = \":8080\"%address = \":12380\"%; s%^address = \"0.0.0.0:9090\"%address = \"0.0.0.0:12390\"%; s%^address = \"0.0.0.0:9091\"%address = \"0.0.0.0:12391\"%; s%:8545%:12345%; s%:8546%:12346%; s%:6065%:12365%" $HOME/cudos-data/config/app.toml
sudo systemctl start cudos-noded && sudo journalctl -u cudos-noded -f --no-hostname -o cat
To catch up quickly, you can either use a snapshot or state sync