laconicd/testnet/full_node.md

3.5 KiB

Instructions to Run Full Node

Hardware

Supported

  • Operating System (OS): Ubuntu 20.04
  • CPU: 1 core
  • RAM: 2GB
  • Storage: 25GB SSD
  • Operating System (OS): Ubuntu 20.04
  • CPU: 2 core
  • RAM: 4GB
  • Storage: 50GB SSD

A) Setup

1) Install Golang (go)

1.1) Remove any existing installation of go

sudo rm -rf /usr/local/go

1.2) Install latest/required Go version (installing go1.17.2)

curl https://golang.org/dl/go1.17.2.linux-amd64.tar.gz
sudo rm -rf /usr/local/go && sudo tar -C /usr/local -xzf go1.17.2.linux-amd64.tar.gz

1.3) Update env variables to include go

cat <<'EOF' >>$HOME/.profile
export GOROOT=/usr/local/go
export GOPATH=$HOME/go
export GO111MODULE=on
export PATH=$PATH:/usr/local/go/bin:$HOME/go/bin
EOF

source $HOME/.profile

1.4) Check the version of go installed

go version

2) Install required software packages

sudo apt-get install git curl build-essential make jq -y

3) Install laconicd

git clone https://github.com/cerc-io/laconicd.git
cd laconicd
git fetch --all
git checkout main
make install

4) Verify your installation

laconicd version --long

On running the above command, you should see a similar response like this. Make sure that the version and commit hash are accurate

name: laconicd
server_name: laconicd

5) Initialize Node

Not required if you have already initialized before

laconicd init <your-node-moniker> --chain-id laconic_81337-2

On running the above command, node will be initialized with default configuration. (config files will be saved in node's default home directory (~/.laconicd/config)

NOTE: Backup node and validator keys . You will need to use these keys at a later point in time.


B) Starting Node

1) Download Final Genesis

Use curl to download the genesis file Replace your genesis file with published genesis file

# Will be updated
curl {GENESIS_LINK} | jq .result.genesis > ~/.laconicd/config/genesis.json

Verify sha256 hash of genesis file with the below command

jq -S -c -M '' ~/.laconicd/config/genesis.json | shasum -a 256

genesis sha256 hash should be

{WILL BE UPDATED}

2) Update Peers & Seeds in config.toml

<!-- Note: don't use peers
peers="5ad2e6c35f2c84ff3ee31d89a95b34d92cb6afb1@157.230.101.237:26656,defc95b08547b6ef254723ad9621967a7e819020@161.35.223.44:26656" -->

{peers={WILL BE UPDATED}}
sed -i.bak -e "s/^persistent_peers *=.*/persistent_peers = \"$peers\"/" ~/.laconicd/config/config.toml

3) Start the Full Node

3.1) Start node as systemctl service

3.1.1) Create the service file

sudo tee /etc/systemd/system/laconicd.service > /dev/null <<EOF
[Unit]
Description=laconicd Daemon
After=network-online.target

[Service]
User=$USER
ExecStart=$(which laconicd) start --gql-playground --gql-server
Restart=always
RestartSec=3
LimitNOFILE=65535

[Install]
WantedBy=multi-user.target
EOF

3.1.2) Load service and start

sudo systemctl daemon-reload
sudo systemctl enable laconicd
sudo systemctl start laconicd

3.1.3) Check status of service


sudo systemctl status laconicd

NOTE: A helpful command here is journalctl that can be used to:

a) check logs


journalctl -u laconicd

b) most recent logs


journalctl -xeu laconicd

c) logs from previous day


journalctl --since "1 day ago" -u laconicd

d) Check logs with follow flag


journalctl -f -u laconicd