This guide will demonstrate how to setup and run a node that connects and synchronises with The Root Network blockchain. You can use your node as backend service for you dapps or participate in securing the network by producing blocks as validator node.
A blockchain's growth comes from a genesis block, extrinsics, and events.
When a validator seals block 1, it takes the blockchain's state at block 0. Subsequently, it then applies all pending changes on top of it and emits the events resulting from these changes. The chain’s state at block 1 is used the same way to build the chain’s state at block 2, and so on. When two-thirds of the validators agree on a specific block being valid, it is finalized.
A full node prunes historical states: all finalized blocks' states older than a configurable number except the genesis block's state. This is 256 blocks from the last finalized one by default. A pruned node this way requires much less space than an archive node - around 50GB depending on number of transactions within the 256 block range.
An archive node keeps all the past blocks and their states. An archive node makes it convenient to query the past state of the chain at any point in time. Finding out what an account's balance at a particular block was or which extrinsics resulted in a specific state change are fast operations when using an archive node. However, an archive node takes up a lot of disk space - around 500GB to 1TB depending on the number of blocks.
A validator node is a full node that is responsible for creating new blocks and validating transactions. These nodes play a crucial role in securing the network and reaching consensus on the state of the blockchain.
Use the latest TRN docker image to get your full node started quickly. Check out the latest version of the docker image here.
The 9944
port mapping is for WebSocket endpoint, and 9933
is for HTTP endpoint. You only need the port mapping if you want to use your node as backend node for your dapps.
First, install Rust. You may need to add Cargo's bin directory to your PATH environment variable.
If you already have Rust installed, ensure you are using the latest version by running:
Build the client by cloning this repository, find the latest version in the [Releases section] and run the following commands from the root directory of the repository:
After the source code is built successfully, you can start your full node with the following command:
The instructions above will have your node running as a full node, to establish an archive node you will need to follow a few additional steps.
Download the latest snapshot.
Extract the snapshot to your node's data directory.
Before running your node, include the following flags, ensuring that the --base-path
points to the directory where the snapshot was extracted.
The fllowing flags will enable the RPC mode for your node, regardless of whether it's full or archive node.
The node startup settings allow you to choose what to expose, how many connections to expose, and from where access should be granted through the RPC server.
How many: You can set your maximum connections using --rpc-max-connections
; for example, --rpc-max-connections=100
.
From where: By default, only localhost is allowed to access the RPC server. You can change this by setting --rpc-cors
; to allow access from everywhere, use --rpc-cors=all
.
And what: You can limit the methods available by using --rpc-methods
. An easy way to set this to a safe mode is --rpc-methods=Safe
.
To safely access your WebSocket (ws) connection over an SSL-enabled connection, you must convert the ws connection to a secure (wss) connection. This can be achieved by utilizing a proxy along with an SSL certificate.
A validator node is essentially a full node with additional flags enabled to participate in securing the network by producing new blocks and validate transactions. For a comprehensive guide on how to become a validator, go here.
Info: Make sure you pick a unique value for the --name
flag so you can identify your node on the Telemetry Hub.
If you are running the validator node in the Docker environment, make sure you have the correct volume mapping to make it easier to upgrade your node client version in the future without the need to re-sync the blocks again.
There are a few useful flags that you can play around with to improve your node performance in various aspects.
It's recommended to use --sync=warp
mode for full node and validator node as it can speed up the syncing process significantly.
Play around with different values of these flags to improve your node read performance.
Add the following flags to enable telemetry reporting of your node on our official Telemetry Hub.
0
The Root Network protocol uses libp2p
to discover peer nodes that your node can connect to exchange and synchronise block information.
In case libp2p
is not working as expected, you can try adding the --reserved-nodes
args, as following, to your node run command to bootstrap it with a list of well-known boot nodes.
Once the run command is updated, please restart your node and let it run for a few hours and see if the peers count is stabilized.
The telemetry connection may fail when using the new Substrate node(v8.56.0
). The following error might be encountered:
This issue is more likely to occur in environments where nodes are running inside Kubernetes. The failure is due to a DNS resolver configuration issue. If you encounter this issue, use the absolute URL for the telemetry as a fix: