Validators are node operators, each storing a copy of the blockchain and performing certain functions to keep the system secure. On The Root Network, validator nodes are responsible for authoring new blocks and participating in the finalization protocol. Validators are an essential part of the Proof-of-Stake consensus mechanism.
Running a validator on a live network is a high-risk, high-reward opportunity. You will be accountable for not only your own stake but also the stake of your current nominators. If a mistake occurs and your node gets slashed, your tokens and your reputation will be at risk. However, running a validator can also be very rewarding, knowing that you contribute to the security of a decentralized network while growing your rewards.
It is highly recommended that you have significant system administration experience before attempting to run your own validator. You must be able to handle technical issues and anomalies with your node which you must be able to tackle yourself. Being a validator involves more than just executing The Root Network binary; it requires a comprehensive understanding of system administration to effectively navigate and troubleshoot various challenges.
A non-custodial FuturePass or an EOA account with at least 5 XRP
to pay for 3 transactions and a minimum 100_000 ROOT
for staking.
A continuous running node that meets the following requirements:
CPU
x86-64 compatible;
Intel Skylake-SP or Cascade Lake; or AMD EPYC or Ryzen;
2 physical cores @ 3.1GHz
Simultaneous multithreading disabled (Hyper-Threading on Intel, SMT on AMD);
Prefer single-threaded performance over higher cores count
x86-64 compatible
Intel Ice Lake-SP; or AMD EPYC or Ryzen;
4 physical cores @ 3.1GHz
Simultaneous multithreading disabled (Hyper-Threading on Intel, SMT on AMD);
Prefer single-threaded performance over higher cores count
Memory
4GB
8GB
Storage
1TB
1TB
Network
Symmetric networking speed at 500 Mbit/s (= 62.5 MB/s)
Symmetric networking speed at 500 Mbit/s (= 62.5 MB/s)
System
Linux Kernel 5.16 or newer
Linux Kernel 5.16 or newer
AWS Instance Type
c5.large
instance
c5.2xlarge
instance
Anyone meeting the above requirements can signal their intention to become a validator. However, only a limited number of validator nodes are elected in each staking era (24 hours). The remaining nodes will be on the waiting list until the next era, to rejoin the election process.
The election process follows a set of well-known algorithms in the Substrate blockchain ecosystem to find the most optimal way to satisfy the three metrics below:
Maximize the total amount at stake.
Maximize the stake behind the minimally staked validator.
Minimize the variance of the stake in the set.
The Root Network will have 42 validator slots for the open beta. This number will increase as the network matures.
Follow the instructions in Running a Node to have your validator node up and running. It's important to have your validator node set up with telemetry support to ensure that it can be properly monitored.
Wait until your node completes the synchronisation before proceeding to the next step. You should see some output similar to the following:
Run a curl
command targeting your node to generate its session keys. This is an important step to link your node with your validator account.
Info: Update the "localhost:9944"
to your node hostname accordingly.
Once the command is executed successfully, you will see a JSON response like this:
The session keys are in the "result"
field of the response, leave the terminal open with the response, as we will need to use it in Step 5.
Go to the Portal Account page and select From Ethereum Wallet.
Select the EOA account with FuturePass that you want to as validator when the “Connect with MetaMask” dialog opens up and click Next.
Confirm both your EOA account and FuturePass account appears on the Account page.
Go to the Portal Extrinsics page and input the values as per the screenshot below:
Click Submit Transaction when done and select Sign when prompted by MetaMask.
The transaction is confirmed when a green tick appears in the top right corner.
Go to the Portal Extrinsics page and input the values as per the screenshot below, with the session keys value from Step 2.
Click Submit Transaction when done and select Sign when prompted by MetaMask.
The transaction is confirmed when a green tick appears in the top right corner.
Go to the Portal Extrinsics page and input the values as per the screenshot below, with the session keys value from Step 2.
Tip: The commission rate is per billion, which means 10000000 = 1%
, 100000000 = 10%
.
Click Submit Transaction when done and select Sign when prompted by MetaMask.
The transaction is confirmed when a green tick appears in the top right corner.
Go to the Portal Staking page and select the Waiting tab and confirm your FuturePass account is on the list, with the correct commission rate:
That’s it, the only thing left is to wait until the next era and see if your validator is elected to be part of the active validators list.
Warning: A single FuturePass account can only be either a validator or a nominator. Avoid using the same FuturePass account to nominate after you've completed the above steps, the Staking protocol will change your role back to nominator at the end of the current era. You will need to repeat these steps to switch back to being a validator.
Validators perform critical functions for the network, and as such, have a strict uptime requirement. Validators may have to go offline for short periods to upgrade client software or the host machine. Usually, standard client upgrades will only require you to stop the service, replace the binary (or the Docker container) and restart the service. This operation can be executed within a session (4 hours) with minimum downtime.
Docker Container
For a node running in a Docker container, follow these steps to upgrade your node client version:
Stop and rename the Docker container so it can be re-created again with the latest image.
Pull the latest Docker image from Github:
Re-create the validator container again using the latest image:
Info: Re-creating the Docker container will not cause your node to re-sync from block 0 again, as long as your Docker container is setup with correct volume mapping as per the instructions.
Confirm your node is working correctly and running the latest version on Telemetry, then remove the old container:
Binary Source
For a node running using binary built from the source, you can follow the steps here to re-build the binary at the latest version and restart your node again.
Validators may also need to perform long-lead maintenance tasks that will span more than one session. Under these circumstances, an active validator may choose to chill their stash, perform the maintenance and request to validate again. Alternatively, the validator may substitute the active validator server with another allowing the former to undergo maintenance activities with zero downtime.
This section will provide an option to seamlessly substitute Node A, an active validator server, with Node B, a substitute validator node, to allow for upgrade/maintenance operations for Node A.
Step 1: At Session N
Follow step 1 and 2 from the Setup Instructions above to setup the new Node B.
Go to the Portal Extrinsics page and input the values as per the screenshot below, with the session keys value from step 2 of the Setup Instructions.
Go to the the Portal Chain State page, query the session.currentIndex()
to take note of the session that this extrinsic was executed in.
Allow the current session to elapse and then wait for two full sessions.
Info:
You must keep Node A running during this time. session.setKeys
does not have an immediate effect and requires two full sessions to elapse before it does. If you do switch off Node A too early you may risk being removed from the active set.
Step 2: At Session N+3
Verify that Node A has changed the authority to Node B by inspecting its log with messages like the ones below:
And in Node B, you should see log messages like these:
Once confirmed, you can safely perform any maintenance operations on Node A and switch back to it by following the step above for Node A. Again, don't forget to keep Node B running until the current session finishes and two additional full sessions have elapsed.
Below are detailed instructions for creating and running a Node.js script to update the validator commission on the Root Network. Below are some important things to keep in mind:
Commission values are in parts per billion (ppb)
Example conversions:
0.75% = 7,500,000 ppb
10% = 100,000,000 ppb
Double-check your commission values before submitting
Keep your validator keys secure
Create a new Node.js project and install dependencies:
Create a script file (e.g., update-commission.js
) with the code below:
Option 1 - Update Using Extrinsics
Go to the Root Network Portal and sign in with your Metamask wallet. Ensure your accounts and Root Balances are visible under the Accounts section. If not, troubleshoot your Metamask connection.
Navigate to the Extrinsics page and set up the commission update call like so:
In the first dropdown, select futurepass
Select proxyExtrinsic(futurepass, call)
Under the FuturePass account, verify it shows: FFFF..0F95
For the call selection:
Select staking
Choose validate(prefs)
Enter your commission value in ppb format (e.g., 7500000 for 0.75%)
Set blocked
to "No"
Review the encoded call data and hash that appear at the bottom of the form.
Click Submit Transaction to proceed with the update.
Sign the transaction with MetaMask when prompted.
Wait for confirmation of the transaction.
Important Notes:
Double-check your commission value is in ppb format before submitting
Verify all nested selections are correct before proceeding
Go to the Portal Extrinsics page and choose Network > Staking from the drop-down menu.
Select the Accounts tab.
Locate your stash account option and choose Change validator preferences.
On the Set Validator Preferences page, enter your commission value in the Reward Commission Percentage field. Example: For 0.75%, enter 0.75
.
Click Validate to confirm and submit the request.
Slashing is implemented as a deterrent for validators to misbehave. Slashes are applied to a validator’s total stake (own + nominated) and can range from as little as 0.01% or rise to 100%. In all instances, slashes are accompanied by a loss of nominators.
A slash may occur under four circumstances:
Unresponsiveness – Slashing starts when 10% of the active validators set are offline and increases in a linear manner until 44% of the validator set is offline; at this point, the slash is held at 7%.
Equivocation – A slash of 0.01% is applied with as little as a single evocation. The slashed amount increases to 100% incrementally as more validators also equivocate.
Malicious Action – This may result from a validator trying to represent the contents of a block falsely. Slashing penalties of 100% may apply.
Application Related (bug or otherwise) – The amount is unknown and may manifest as scenarios 1, 2, and 3 above.
This section provides some best practices to prevent slashing based on lessons learned from previous slashes from the Polkadot network. It provides comments and guidance for all circumstances except for malicious action by the node operator.
An offline event occurs when a validator does not produce a BLOCK or IMONLINE message within an EPOCH. Isolated offline events do not result in a slash; however, the validator would not earn any work points while offline. A slash for unresponsiveness occurs when 10% or more of the active validators are offline at the same time.
The following are recommendations to validators to avoid slashing under liveliness for servers that have historically functioned:
Utilize systems to host your validator instance. Systemd should be configured to auto reboot the service with a minimum 60-second delay. This configuration should aid with re-establishing the instance under isolated failures with the binary.
A validator instance can demonstrate un-lively behaviour if it cannot sync new blocks. This may result from insufficient disk space or a corrupt database.
Monitoring should be implemented that allows node operators to monitor connectivity network connectivity to the peer-to-peer port of the validator instance. Additionally, monitoring should ensure that there is a drift of less than 50 blocks between the target and best blocks. If either event produces a failure, the node operator should be notified.
The following are recommendations to validators to avoid liveliness for new servers / migrated servers:
Ensure that the --validator
flag is used when starting the validator instance.
If switching keys, ensure that the correct session keys are applied.
If migrating using a two-server approach, ensure that you don’t switch off the original server too soon.
Ensure that the database on the new server is fully synchronized.
It is highly recommended to avoid hosting on providers that other validators may also utilize. If the provider fails, there is a probability that one or more other validators would also fail due to liveliness building to a slash.
Equivocation events can occur when a validator produces two or more identical blocks; in this case, it is called a BABE equivocation. Equivocation may also happen when a validator signs two or more of the identical consensus votes; in this case, it is called a GRANDPA Equivocation. Equivocations usually occur when duplicate signing keys reside on the validator host. If keys are never duplicated, the probability of an equivocation slash decreases to near 0.
The following are scenarios that build towards slashes under equivocation:
Cloning a server, i.e., copying all contents when migrating to new hardware, should be avoided. If an image is desired, it should be taken before keys are generated.
High Availability (HA) Systems – Equivocation can occur if there are any concurrent operations, either when a failed server restarts or if a false positive event results in both servers being online simultaneously. HA systems are to be treated with extreme caution and are not advised.
The keystore folder is copied when attempting to copy a database from one instance to another.
Note: Equivocation slashes occur with a single incident. This can happen if duplicated key stores are used for only a few seconds.
The following are advised to node operators to ensure that they obtain pristine binaries or source code and to ensure the security of their node:
Always download either source files or docker images from the official Root Network repository
Verify the hash of downloaded files.
Use the W3F secure validator setup or adhere to its principles
Ensure that essential security items are checked, including the use of a firewall, proper management of user access, and the implementation of SSH certificates.
Avoid using your server as a general-purpose system. Hosting a validator on your workstation or one that hosts other services increases the risk of maleficence.