Running a Node
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.
Node Types
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.
Run a Full Node with Docker
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 and HTTP endpoints. You only need the port mapping if you want to use your node as backend node for your dapps.
Run a Full Node from Source
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:
Run an Archive Node
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.
Run a RPC Node
The fllowing flags will enable the RPC mode for your node, regardless of whether it's full or archive node.
Secure the RPC 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
.
Secure the WebSocket Port
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.
Run a Validator Node
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.
Node Update Guidelines
To ensure smooth network operation, it is essential to understand when and how to update nodes based on the versioning system. This guide clarifies the versioning format and when validator participation is required for updates.
Versioning Format
Node versioning follows a three-part format:
The Client version represents a client update and requires validators to update their nodes manually. We will explicitly communicate when a client upgrade is required.
Example: Moving from
8.x.x
to9.x.x
.The Runtime version represents a runtime update, which propagates naturally through the network using the Substrate framework. Unless specified otherwise, validators do not need to take manual action for runtime updates. Example: Moving from
8.63.0
to8.64.0
.The Patch number reflects minor changes or fixes. These updates typically do not require immediate action
Useful Flags
There are a few useful flags that you can play around with to improve your node performance in various aspects.
Sync Mode
It's recommended to use --sync=warp
mode for full node and validator node as it can speed up the syncing process significantly.
Runtime Caching
Play around with different values of these flags to improve your node read performance.
Telemetry
Add the following flags to enable telemetry reporting of your node on our official Telemetry Hub.
Known Issues
Peers connection intermittently drops to 0
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.
Telemetry connection failure
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:
Last updated