# How to Run PoS Node
With Enecuum, it is possible to use the Trinity protocol (a combination of PoA, PoS and PoW) as well as functionality such as ETM (Enecuum Token Machine), delegation to PoS nodes (delegated smart staking), issuing of different types of tokens - mining, NFT and other.
# Staking and PoS Contracts
General idea of staking is depositing (or "delegating" as we call it below) your funds to PoS-nodes to increase their stake power to remain in top 100 wallets (as only the richest wallets are allowed to perform PoS work) for a share from PoS mining rewards. To guarantee it, this share is calculated thoroughly, and in time, PoS contracts are introduced. These contracts control delegated funds in a way that they can be used only for PoS mining and a delegator can always return coins.
So if you want to run a PoS node you should create a PoS contract first (make a special transaction). Then, you can run a node - a piece of software associated with the PoS contract.
Think of it this way: when you create a PoS contact, you establish a bank. When you delegate your funds to a PoS contract, you open a bank deposit.
# Creating a PoS Contract
To create a PoS contract, use a web-wallet interface.
There two input fields. PoS contract name, which can be left blank, and a PoS contract fee. Contract fee determines the "salary" PoS owner receives for running a server. Choose it wisely, as if you set it too small, you can loose money paying for your sever; but if you set it too high, nobody will delegate funds to you and you can be out of top 100 with no earning at all. This commission percent will be adjustable in the future but with first release it cannot be changed after creation.
After confirming PoS contract transaction and paying a transaction fee, please wait a bit. You will see a new record in the blockchain. Please find you contract at PoS contracts page. If your PoS name is blank, you can find your contract by owner address. It should be the wallet you used to send PoS contract creation transaction.
Click Hash value of your contract to copy your PoS contract hash (address). In this test case, it is 17d0b43aafb141dbc4e36ae0abefc2b28b3979f96a84cdecf7e26dc25bd1c042, as can be seen in the figure above, marked with red. The hash will be used in the next step.
In order for the contact to become active, you need to fulfill this requirements:
- delegate 25001 ENQ to the created contact from the same wallet, used for the contract creation;
- be in the top 100 rating of PoS contracts;
- run the PoS node.
# Delegating to Your PoS Contract
In order for the contract to become active, you need to delegate to it. A minimal self-delegated stake is 25001 ENQ.
To find out how to delegate your funds, refer to the according guide.
# Running a PoS Node
Note that PoW and Fullnode can only work with public IP addresses. The IP address can be static or dynamic.
Minimal hardware requirements are 1 CPU, 2 GB of RAM, 20 GB of disk. These are like of a small VPS server offered by the majority of hosting providers. Disk requirements will rise with the size of the blockchain and are estimated as 1 TB in 1-2 years. Please note this minimal hardware may not let your node to achieve maximum performance (and rewards). Recommended hardware requirements will be published after PoS software updates bringing planned optimizations.
Current build nodes work stable only on Linux OS. There are network issues running nodes on Windows and Mac.
components are deployed through Docker, a platform meant for building, sharing, and running applications with containers. So first of all, download Docker for your OS using official guides. For Windows users, we recommend Docker Toolbox. Linux users can follow Docker guide for Ubuntu.
After installing Docker, download the database that will be used in your Fullnode, PoW or PoS. This is a mandatory step.
docker run -d --name pulse_db -e MYSQL_ROOT_PASSWORD=<your_db_password> enecuum/pulse_db
Working with Docker is easy. The following list of commands should be enough for basic use:
- stop the container:
docker stop <container-name>;
- show stopped containers:
docker ps -a;
- start the container:
docker start <container-name>;
- show active containers:
- show logs:
docker logs <container-name>;
- show Docker disk usage:
docker system df -v.
- stop the container:
You can stop/restart the container without worrying; no data will be lost.
# How to Run PoS
Carefully read the prerequisites above. Check that you have the database installed:
A container named pulse_db should appear:
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 0f59855cf0ea enecuum/pulse_db "docker-entrypoint.s…" 6 seconds ago Up 5 seconds 33060/tcp pulse_db
If you don't see the container in the list, please follow the instructions provided in the prerequisites.
Generate public and private keys using Enecuum App or Web Wallet. Do a backup copy. You can use the same key pair for PoA, PoS and PoW.
Create a PoS contract via web-wallet as this guide states.
Download and run PoS container:
docker run -ti --name pulse_pos --link pulse_db:dbhost -p8000:8000 -e POS_ID=<your_pos_id> -e PORT=8000 -e DB_PASS='<your_db_password>' -e PEER='22.214.171.124:8000' -e DB_PORT=3306 -d enecuum/pulse_pos
<your_pos_id>parameter value to the PoS contract hash without brackets <>. You can use the hash from the previous step as the POS_ID parameter. Type your database password in
Check if your container is running:
A list with pulse_db and pulse_pos containers should appear.
Wait for synchronization to be completed. After that you PoS-contract will be displayed as "Active" and its performance will rise with each published s-block. You can compare current block number from the Blockchain Explorer with your nodes current block with
docker logs pulse_pos | grep n: | tailcommand.
# View Your Delegators and Rewards
At the PoS contract page (list of all contracts is here), you can find the amount of delegated coins and rewards that your contract receives. Please note that rewards shown in the Blockchain Explorer are split between PoS owner and its delegators according to your PoS fee value.