Run a Mainnet Node
Hardware Requirements
The minimum and recommended requirements to run a Mainnet Persistence Node increase as it produces more blocks and more features are added. Thus, there are no exact hardware requirements that are permanently sufficient. A mainnet node should always have redundant resources available.
Recommended:
16 GB RAM (or more)
500 GB SSD (or more)
4 CPU (or more)
100mbps Network Bandwidth (or more)
Operating System:
Recommended: Linux(x86_64)
Others: Windows/MacOS(x86)
Prerequisites
To successfully run a Persistence Mainnet Node, we need to install a few prerequirements. Because running the Persistence software depends on them, prerequirements are also known as dependencies.
We need to install and/or setup 5 dependencies - Go, jq, gcc, make, and git.
Install Go
Ubuntu
Remove any previous installation:
Add the Go PPA to Your System:
First, add the
longsleep/golang-backports
PPA to your system. This repository contains the latest version of Go. You can add it by running the following command in your terminal:Update Your Package List:
After adding the PPA, update your package list to include the latest packages available in the repository:
Install Go:
Now, install Go using the
apt
package manager. This command will install the latest version of Go available in the PPA:Set Up Your Go Environment: After installation, set up your Go workspace and add Go binaries to your PATH. You can do this by adding the following lines to your
~/.profile
file:Verify the Installation:
Finally, verify that Go has been installed correctly by checking its version. You should see the latest version of Go as the output:
macOS
Install Homebrew (if not already installed): If you don't have Homebrew on your macOS, you need to install it first. Visit the Homebrew website for installation instructions.
Install Go using Homebrew: Open a terminal and run the following command:
To ensure Go is installed correctly, check its version. In the terminal, type:
Install jq, git, gcc, and make
Install:
Ubuntu:
apt install jq git gcc make
macOS:
brew install jq git gcc make
Verify Installations:
Verify jq:
jq --version
(sample output:jq-1.6
)Verify gcc :
gcc --version
(sample output:gcc (Ubuntu 9.4.0-1ubuntu1~20.04.1) 9.4.0
)Verify make:
make --version
(sample output:GNU Make 4.2.1
)Verify git:
git --version
(sample output:git version 2.25.1
)
Installation Steps
Install the persistenceCore Binary
Note The latest version available in the releases page might not be the one running on the core-1 chain. To ensure you're running the correct version, join the Discord Mainnet Validator Announcements Channel.
Clone the persistenceCore repository:
Check what version is running on the core-1 chain by visiting the Discord Mainnet Validators Announcements Channel.
Switch to the branch of the latest version (v6.1.0 as of time of writing):
Install the persistenceCore binary:
Verify installation (sample output:
v6.1.0
):
Create or Import Key (XPRT Address)
Create key (ensure you safely store the mnemonic seed phrase):
Recover key (you'll be required to input your mnemonic seed phrase):
Verify the key was created successfully:
Create and Sync the Node
Initialize the node (moniker = node name):
Download the core-1 genesis file:
Use StateSync to sync with the rest of the nodes. Follow the step-by-step guide below:
Run the following command and copy the values of
trust_height
andtrust_hash
. They are required in the next steps.Open config:
Replace the existing settings in the opened file with the following:
Make sure you replace
trust_height
andtrust_hash
values with the ones you've copied in the previous step.
Open the
app.toml
file (application-related configuration file):Change
minimum-gas-prices
tominimum-gas-prices = "0.005uxprt"
Start the node:
Because we used StateSync to sync with the other nodes, it shouldn't take more than 10 minutes to complete. In the meantime, a lot of output messages will pop one after another.
When the node is completely synced, you should observe a similar output:
Alternatively, you can use the following command (response must be
false
):
Node operations
Upgrade the Node's Software
Last updated