PoS Validator
data:image/s3,"s3://crabby-images/cc892/cc89274610399502511cd38d24800d0ee4d103b5" alt="Vana banner"
PoS Validator Setup
https://docs.vana.org/vana/core-concepts/roles/propagators
1. Prerequisites
You need to submit deposits for each validator at least 35,000 VANA on Moksha testnet. This process stakes your VANA and registers your validator(s) with the network
Hardware requirements for Testnet
- 2-core CPU
- 8 GB RAM
- 100 GB high-speed SSD
- x86-64 architecture
These hardware requirements are rough guidelines, and each node operator should monitor their node to ensure good performance for the intended task.
- Docker: Install Docker
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpgecho "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
sudo apt-get updatesudo apt-get install docker-ce docker-ce-cli containerd.iodocker version
data:image/s3,"s3://crabby-images/e3a29/e3a29f53aefad0cba0085cdb0c8a5551f81cb3e0" alt="banner"
data:image/s3,"s3://crabby-images/67a40/67a4002ae0b52d5ac41200d1f376dc62ace94c18" alt="banner"
- Docker Compose: Install Docker Compose
VER=$(curl -s https://api.github.com/repos/docker/compose/releases/latest | grep tag_name | cut -d '"' -f 4)curl -L "https://github.com/docker/compose/releases/download/"$VER"/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
chmod +x /usr/local/bin/docker-composedocker-compose --version
data:image/s3,"s3://crabby-images/a82b8/a82b83b698668ed9c800646dd7c7ccc20782418f" alt="banner"
- OpenSSL: Install via your package manager:
sudo apt-get install openssl
data:image/s3,"s3://crabby-images/73191/73191dfbb11794c6cc927a055701502a0e8ac411" alt="banner"
2. Clone the repository:
git clone https://github.com/vana-com/vana-private.gitcd vana-private
3. Configure your environment:
# For Moksha testnetcp .env.moksha.example .env
# For Mainnetcp .env.mainnet.example .env
Edit .env with your preferred text editor
nano .env
data:image/s3,"s3://crabby-images/12b0a/12b0a428de777f48058c19236124e879e658c4c4" alt="banner"
4. Choose your setup:
a. For running a node without a validator:
Edit the .env
file to set the USE_VALIDATOR
variable to false
. It is recommended to use GETH_SYNCMODE=snap
and to update the Prysm variables to match, per the comments in the .env.example
file. Then run the following commands:
docker compose --profile init --profile node up -d
b. For running a validator node:
Edit the .env
file to set the USE_VALIDATOR
variable to true
and set the DEPOSIT_*
variables to the appropriate values. Then run the following commands:
- Generate validator keys (interactive process):
docker compose --profile init --profile manual run --rm validator-keygen
data:image/s3,"s3://crabby-images/182f7/182f72f639306481203482732874cb9d6234ed3d" alt="banner"
Setting an Eth1 address as your withdrawal address:
- Create a password that secures your validator keystore(s):
data:image/s3,"s3://crabby-images/0890e/0890ecb6b0df558b304398ecef451cecc403e26d" alt="banner"
- Save your mnemonic carefully:
data:image/s3,"s3://crabby-images/9c075/9c075dba5e114cba232965b9a4a87c398852a0b0" alt="banner"
- Verify your mnemonic phrase
data:image/s3,"s3://crabby-images/43bbc/43bbc5e91c4485aba1da064bdd5cfe46030c5e47" alt="banner"
data:image/s3,"s3://crabby-images/34d9e/34d9e68592c1cbf5c2ca33711dc0758cc291725b" alt="banner"
Check config:
docker compose --profile init logs check-config-node
data:image/s3,"s3://crabby-images/18ad4/18ad423bbf7ea1e5c5c1846ff2017638f9416642" alt="banner"
Start all services including the validator:
docker compose --profile init --profile validator up -d
data:image/s3,"s3://crabby-images/db7a0/db7a006a10c88c8803bb65742a7059106e11dcbb" alt="banner"
View logs for specific key services:
docker compose --profile=init --profile=node logs -f gethdocker compose --profile=init --profile=node logs -f beacondocker compose --profile=init --profile=node logs -f validator
data:image/s3,"s3://crabby-images/14404/144047acae89b480acb6f69ad537aa29cf6e2457" alt="banner"
data:image/s3,"s3://crabby-images/aaa5e/aaa5ea58cd7bd7527f250529261d499fc8e58afd" alt="banner"
Wait for beacon chain full synced
data:image/s3,"s3://crabby-images/1078b/1078bb9aeb74265a874e9608e743fa98ff19c259" alt="banner"
data:image/s3,"s3://crabby-images/a9898/a989851acba3250e01ebe6e94427ca61d2b76b99" alt="banner"
Submit deposits for your validator
You need to submit deposits for each validator at least 35,000 VANA on Moksha testnet. This process stakes your VANA and registers your validator(s) with the network
docker compose --profile init --profile manual run --rm submit-deposits
data:image/s3,"s3://crabby-images/ea404/ea404cb0951e6f7fba39f93f867ed3024deb31c2" alt="banner"
Check block sync left:
LOCAL_RPC="http://localhost:$(grep HTTP_PORT ~/vana-private/.env | cut -d '=' -f2)"REMOTE_RPC="https://rpc.moksha.vana.org"get_block_number() { curl -s -X POST "$1" \ -H "Content-Type: application/json" \ -d '{"jsonrpc":"2.0","method":"eth_blockNumber","params":[],"id":1}' | \ jq -r '.result' | \ xargs -I{} printf "%d" {}}while true; do local_height=$(get_block_number $LOCAL_RPC) network_height=$(get_block_number $REMOTE_RPC) blocks_left=$((network_height - local_height)) echo -e "\033[1;38mYour node height:\033[0m \033[1;34m$local_height\033[0m | \033[1;35mNetwork height:\033[0m \033[1;36m$network_height\033[0m | \033[1;29mBlocks left:\033[0m \033[1;31m$blocks_left\033[0m" sleep 5done
data:image/s3,"s3://crabby-images/a96c9/a96c9ab438681ae1b624174b547cef95a7ec697f" alt="banner"
# Advanced Usage
The docker-compose.yml
file provides several additional capabilities for managing your Vana PoS validator node. Here are some useful commands and their purposes:
Profiles
Different profiles are available for various operations:
init
: Initialize clients, generate secretsnode
: Run the main node servicesvalidator
: Run validator-specific servicesmanual
: For manual operations like key generationdelete
: Delete data, e.g. to reset the chain so you can re-sync
You can combine profiles as needed. Whenever a service depends on another service, you must include the dependent profile.
For example, to start the node, you must include the init
and node
profiles:
#Start nodedocker compose --profile init --profile node up -d
#Stop nodedocker compose --profile init --profile node down
Key Management
Generate validator keys (interactive process):
docker compose --profile init --profile manual run --rm validator-keygen
Import validator keys:
docker compose run --rm validator-import
Deleting Data
To delete all data/ (does not remove generated secrets/):
docker compose --profile delete run --rm delete-all
To delete execution or consensus layer data:
docker compose --profile delete run --rm delete-gethdocker compose --profile delete run --rm delete-prysm
Configuration Check
Run a configuration check:
docker compose --profile=init --profile=node run --rm check-config
Individual Services
You can start, stop, or restart individual services:
docker compose --profile=init --profile=node up -d gethdocker compose --profile=init --profile=node stop beacondocker compose --profile=init --profile=node restart validator
Viewing Logs
View logs for specific services:
docker compose --profile=init --profile=node logs gethdocker compose --profile=init --profile=node logs beacondocker compose --profile=init --profile=node logs validator
Add -f
to follow the logs in real-time:
docker compose --profile=init --profile=node logs -f geth
Use grep to filter for specific events:
docker compose --profile=init --profile=node logs -f geth 2>&1 | grep 'Looking for peers'docker compose --profile=init --profile=node logs -f beacon 2>&1 | grep 'Synced new block'docker compose --profile=init --profile=node logs -f validator 2>&1 | grep 'Submitted new'