logo
ANDROMEDA

Installation

Recommended Hardware: 4 Cores, 4GB RAM, 500GB of storage (NVME)

Node Name
Wallet
Port
Add
# set environment variables
echo "export WALLET="wallet"" >> $HOME/.bash_profile
echo "export MONIKER="moniker"" >> $HOME/.bash_profile
echo "export CHAIN_ID="seda-1"" >> $HOME/.bash_profile
echo "export PROJECT="seda"" >> $HOME/.bash_profile
echo "export NETWORK="mainnet"" >> $HOME/.bash_profile
echo "export DIRECTORY="$HOME/.sedad"" >> $HOME/.bash_profile
source $HOME/.bash_profile

# install dependencies
sudo apt -q update
sudo apt -qy install curl git jq lz4 build-essential fail2ban ufw
sudo apt -qy upgrade

# install go
cd $HOME
bash <(curl -s "https://raw.githubusercontent.com/Andromeda-node/utils/main/auto_go_install.sh") -v 1.21.6
source ~/.bash_profile

# download binary
cd $HOME 
rm -rf seda-chain 
git clone https://github.com/sedaprotocol/seda-chain.git 
cd seda-chain 
git checkout v0.1.1 
make install

# config and init app
sedad config keyring-backend os
sedad config chain-id seda-1
sedad init "moniker" --chain-id seda-1

# download genesis and addrbook
wget -O $HOME/.sedad/config/genesis.json https://snap.nodex.one/seda/genesis.json
wget -O $HOME/.sedad/config/addrbook.json https://snap.nodex.one/seda/addrbook.json

# set seeds and peers
SEEDS=""
PEERS=""
sed -i -e "s/^seeds *=.*/seeds = \"$SEEDS\"/; s/^persistent_peers *=.*/persistent_peers = \"$PEERS\"/" $HOME/.sedad/config/config.toml


# config pruning
sed -i -e "s/^pruning *=.*/pruning = \"custom\"/" $HOME/.sedad/config/app.toml
sed -i -e "s/^pruning-keep-recent *=.*/pruning-keep-recent = \"100\"/" $HOME/.sedad/config/app.toml
sed -i -e "s/^pruning-interval *=.*/pruning-interval = \"50\"/" $HOME/.sedad/config/app.toml

# set minimum gas price, enable prometheus and disable indexing
sed -i 's|minimum-gas-prices =.*|minimum-gas-prices = "10000000000aseda"|g' $HOME/.sedad/config/app.toml
sed -i -e "s/prometheus = false/prometheus = true/" $HOME/.sedad/config/config.toml
sed -i -e "s/^indexer *=.*/indexer = \"null\"/" $HOME/.sedad/config/config.toml

# create and enable service file
sudo tee /etc/systemd/system/sedad.service > /dev/null <<EOF
[Unit]
Description=Seda node
After=network-online.target
[Service]
User=$USER
WorkingDirectory=$HOME/.sedad
ExecStart=$(which sedad) start --home $HOME/.sedad
Restart=on-failure
RestartSec=5
LimitNOFILE=65535
[Install]
WantedBy=multi-user.target
EOF
sudo systemctl daemon-reload
sudo systemctl enable sedad

# download latest chain data snapshot
if curl -s --head https://files.andromedanode.co/seda/snap_seda.tar.lz4 | head -n 1 | grep "200" > /dev/null; then
    curl https://files.andromedanode.co/seda/snap_seda.tar.lz4 | lz4 -dc - | tar -xf - -C $HOME/.sedad
else
    bash <(curl -s https://raw.githubusercontent.com/Andromeda-node/utils/main/snapshot_finder.sh)
fi

# start service
sudo systemctl restart sedad && sudo journalctl -u sedad -f --no-hostname -o cat

Create validator

Moniker
Identity
Details
Amount, aseda
Commission rate
Commission max rate
Commission max change rate
Website
#private validator key
sedad comet show-validator

sudo tee $HOME/.sedad/validator.json > /dev/null <<EOF
{
    "pubkey": {"#output private validator key},
    "amount": "1000000aseda",
    "moniker": "moniker",
    "identity": "",
    "website": "https://andromedanode.co/",
    "details": "A heartfelt shoutout to Andromeda for their amazing support! Your contributions shine brightly, guiding us forward. We are deeply grateful. And to the world of blockchain, our love knows no bounds. ❤️ Thank you, Andromeda, for being such a vital part of our journey.",
    "commission-rate": "0.1",
    "commission-max-rate": "0.2",
    "commission-max-change-rate": "0.01",
    "min-self-delegation": "1"
}
EOF

sedad tx staking create-validator $HOME/.sedad/validator.json \
--from=$WALLET \
--chain-id=seda-1 \
--gas auto --fees 0.025aseda

Security

Firewall security

Set the default to allow outgoing connections, deny all incoming, allow ssh and node p2p port

sudo apt install -y ufw
sudo ufw default allow outgoing 
sudo ufw default deny incoming 
sudo ufw allow ssh/tcp 
sudo ufw allow 26656/tcp
sudo ufw enable

Delete node

cd $HOME
sudo systemctl stop sedad 
sudo systemctl disable sedad 
sudo rm /etc/systemd/system/sedad.service 
sudo systemctl daemon-reload 
sudo rm -rf $HOME/.sedad
sudo rm -rf $(which sedad)