dYdX Node Installation Guide

Chain ID: dydx-mainnet-1 | Current Node Version: v7.0.5

Install Go and Cosmovisor

Feel free to skip this step if you already have Go and Cosmovisor.

Install Go

We will use Go v1.23.4 as example here. The code below also cleanly removes any previous Go installation.

sudo rm -rvf /usr/local/go/
wget https://golang.org/dl/go1.23.4.linux-amd64.tar.gz
sudo tar -C /usr/local -xzf go1.23.4.linux-amd64.tar.gz
rm go1.23.4.linux-amd64.tar.gz

Configure Go

Unless you want to configure in a non-standard way, then set these in the ~/.profile file.

export GOROOT=/usr/local/go
export GOPATH=$HOME/go
export GO111MODULE=on
export PATH=$PATH:/usr/local/go/bin:$HOME/go/bin

Install Cosmovisor

We will use Cosmovisor v1.0.0 as example here.

go install github.com/cosmos/cosmos-sdk/cosmovisor/cmd/[email protected]

Install Node

Install the current version of node binary.

git clone https://github.com/dydxprotocol/v4-chain dydx
cd dydx
git checkout v7.0.5
make install

Configure Node

Initialize Node

Please replace YOUR_MONIKER with your own moniker.

dydxprotocold init YOUR_MONIKER --chain-id dydx-mainnet-1

Download Genesis

The genesis file link below is Polkachu's mirror download. The best practice is to find the official genesis download link.

wget -O genesis.json https://snapshots.polkachu.com/genesis/dydx/genesis.json --inet4-only
mv genesis.json ~/.dydxprotocol/config

Configure Seed

Using a seed node to bootstrap is the best practice in our view. Alternatively, you can use addrbook or persistent_peers.

sed -i 's/seeds = ""/seeds = "[email protected]:23856"/' ~/.dydxprotocol/config/config.toml

Launch Node

Configure Cosmovisor Folder

Create Cosmovisor folders and load the node binary.

# Create Cosmovisor Folders
mkdir -p ~/.dydxprotocol/cosmovisor/genesis/bin
mkdir -p ~/.dydxprotocol/cosmovisor/upgrades

# Load Node Binary into Cosmovisor Folder
cp ~/go/bin/dydxprotocold ~/.dydxprotocol/cosmovisor/genesis/bin

Create Service File

Create a dydx.service file in the /etc/systemd/system folder with the following code snippet. Make sure to replace USER with your Linux user name. You need sudo privilege to do this step.

[Unit]
Description="dydx node"
After=network-online.target

[Service]
User=USER
ExecStart=/home/USER/go/bin/cosmovisor start
Restart=always
RestartSec=3
LimitNOFILE=4096
Environment="DAEMON_NAME=dydxprotocold"
Environment="DAEMON_HOME=/home/USER/.dydxprotocol"
Environment="DAEMON_ALLOW_DOWNLOAD_BINARIES=false"
Environment="DAEMON_RESTART_AFTER_UPGRADE=true"
Environment="UNSAFE_SKIP_BACKUP=true"

[Install]
WantedBy=multi-user.target

Download Snapshot

Please use our popular snapshot download service to download and extract dYdX snapshot.

Start Node Service

# Enable service
sudo systemctl enable dydx.service

# Start service
sudo service dydx start

# Check logs
sudo journalctl -fu dydx

Other Considerations

This installation guide is the bare minimum to get a node started. You should consider the following as you become a more experienced node operator.

  • Use Ansible script to automate the node installation process
  • Configure firewall to close most ports while only leaving the p2p port (typically 26656) open
  • Use custom ports for each node so you can run multiple nodes on the same server

If you find a bug in this installation guide, please reach out to our Discord Server and let us know.