This article assumes that /blockchain
directory will be used to store all files created by the node client. It is also assumed that this directory will be one to one mapped as a volume into a Docker containers. You can replace this directory with any other location of your choice, however directory must be created with permissions allowing Docker to write there, before you proceed further.
Types of nodes
PulseChain node software is composed of 2 client components:
- Execution Layer (EL) which can be:
- go-pulse (geth) - Docker image
registry.gitlab.com/pulsechaincom/go-pulse
. - Erigon - Docker image
registry.gitlab.com/pulsechaincom/erigon-pulse
.
- go-pulse (geth) - Docker image
- Consensus Layer (CL) which can be:
- Prysm - An implementation of the consensus protocol with a focus on usability, security, and reliability. Originally developed by Prysmatic Labs, a company with the sole focus on the development of their client.
- Docker image
registry.gitlab.com/pulsechaincom/prysm-pulse/beacon-chain
.
- Docker image
- Lighthouse - A consensus client with a heavy focus on speed and security. Originally built by Sigma Prime, an information security and software engineering firm who have funded Lighthouse along with the Ethereum Foundation, Consensys, and private individuals.
- Docker image
registry.gitlab.com/pulsechaincom/lighthouse-pulse
.
- Docker image
- Prysm - An implementation of the consensus protocol with a focus on usability, security, and reliability. Originally developed by Prysmatic Labs, a company with the sole focus on the development of their client.
You can combine any EL client and any CL client, but geth
+ lighthouse
seems to be the easiest option. EL client will not work without CL.
In most cases you should use Docker image tagged as latest
. By default Docker caches it’s images therefore it’s always good to run:
docker pull <registry-image-path>
to ensure you have the right Docker image content, before your run or start a Docker container with that image.
All mentioned Docker container are preconfigured to run specific node command and therefore any arguments added to the docker run
command are passed as argument to the client command invoked within the container.
Setting up RPC node
Securing EL and CL communication
EL and CL clients need to communicate using Engine API and for this purpose you need to create secret encryption key, so called JWT Secret. You can use standard openssl
command line tool to do so:
openssl rand -hex 32 | tr -d "\n" > /blockchain/jwt.hex
(note that key must not contain the trailing newline).
Official PulseChain documentation recommends using Docker on “host” network. It is bit safer to create a virtual network for EL and CL clients’ communication. You can do it by running:
docker network create pulsenet
Running EL geth node
You can manually setup the go-pulse
Docker container with PulseChain Execution Layer node by running:
docker run -d \
--stop-timeout=180 \
--restart always \
--net=pulsenet \
--name=pulsechain_execution \
-p 127.0.0.1:8545:8545/tcp \
-p 127.0.0.1:8546:8546/tcp \
-p 30303:30303 \
-v /blockchain:/blockchain \
registry.gitlab.com/pulsechaincom/go-pulse:latest \
--pulsechain-testnet-v4 \
--datadir=/blockchain/geth \
--authrpc.jwtsecret=/blockchain/jwt.hex \
--authrpc.addr=0.0.0.0 \
--authrpc.vhosts=pulsechain_execution \
--ws \
--ws.api=eth,net,web3 \
--ws.addr=0.0.0.0 \
--http \
--http.api=eth,net,web3 \
--http.addr=0.0.0.0
TODO: –gcmode=archive
For node’s P2P connectivity the TCP and UDP port 30303 should be made accessible from your network and also from the Internet.
All the --ws*
and --http
switches, together with 8545 and 8546 port mappings can be removed, if you don’t want to use your node as RPC service provider. Note that RPC ports 8545 (HTTP) and 8646 (WebSockets) are only allowed locally on the host computer.
To see the logs of the container run:
docker logs -f pulsechain_execution
Here the optional -f
flag allows follow mode for tracking new logged lines.
Typical messages and what they mean:
Post-merge network, but no beacon client seen. Please launch one to follow the chain!
- this means that no CL client connected to this EL client.
Running EL Erigon node
You can manually setup the erigon
Docker container with PulseChain Execution Layer node by running:
docker run -d \
--stop-timeout=180 \
--restart always \
--net=pulsenet \
--name=pulsechain_execution \
-p 127.0.0.1:8545:8545/tcp \
-p 30303:30303 \
-p 30304:30304 \
-p 42069:42609 \
-v /blockchain:/blockchain \
registry.gitlab.com/pulsechaincom/erigon-pulse:latest \
--chain=pulsechain-testnet-v4 \
--datadir=/blockchain/erigon \
--authrpc.jwtsecret=/blockchain/jwt.hex \
--authrpc.addr=0.0.0.0 \
--authrpc.vhosts=pulsechain_execution \
--externalcl \
--snapshots=false
For node’s P2P connectivity the TCP and UDP port 30303, 30304 and 42069 should be made accessible from your network and also from the Internet.
Note that RPC ports 8545 (HTTP + WebSockets) are only allowed locally on the host computer.
To see the logs of the container run:
docker logs -f pulsechain_execution
Here the optional -f
flag allows follow mode for tracking new logged lines.
Running CL Lighthouse node
You can manually setup the lighthouse-pulse
Docker container with PulseChain Consensus Layer node by running:
docker run -d \
--stop-timeout=180 \
--restart always \
--net=pulsenet \
--name=pulsechain_consensus \
-p 9000:9000 \
-v /blockchain:/blockchain \
registry.gitlab.com/pulsechaincom/lighthouse-pulse \
lighthouse \
beacon_node \
--network=pulsechain_testnet_v4 \
--datadir=/blockchain/lighthouse \
--execution-jwt=/blockchain/jwt.hex \
--execution-endpoint=http://pulsechain_execution:8551 \
--checkpoint-sync-url=https://checkpoint.v4.testnet.pulsechain.com \
--http \
--http-address 127.0.0.1
This command assumes that EL client exposes JWT interface on port 8551 (pulsechain_execution
virtual address of it on the pulsenet
virtual network).
For node’s P2P connectivity the TCP and UDP port 9000 should be made accessible from your network and also from the Internet. Note, that this Docker container is setup with host
networking what makes it directly exposed to the network of the host where the container runs and the -p
port mappings are ignored - they are stated to clarified which ports should be exposed in more general case.
Running CL Prysm node
You can manually setup the prysm-pulse
Docker container with PulseChain Consensus Layer node by running:
docker run -d \
--stop-timeout=180 \
--restart always \
--net=pulsenet \
--name=pulsechain_consensus \
-p 9000:9000 \
-p 127.0.0.1:5052:5052 \
-v /blockchain:/blockchain \
registry.gitlab.com/pulsechaincom/prysm-pulse/beacon-chain \
--pulsechain-testnet-v4 \
--datadir=/blockchain/prysm \
--jwt-secret=/blockchain/jwt.hex \
--execution-endpoint=http://pulsechain_execution:8551 \
--checkpoint-sync-url=https://checkpoint.v4.testnet.pulsechain.com \
--genesis-beacon-api-url=https://checkpoint.v4.testnet.pulsechain.com
This command assumes that EL client exposes JWT interface on port 8551 (pulsechain_execution
virtual address of it on the pulsenet
virtual network).
For node’s P2P connectivity the TCP and UDP port 9000 should be made accessible from your network and also from the Internet. Note, that this Docker container is setup with host
networking what makes it directly exposed to the network of the host where the container runs and the -p
port mappings are ignored - they are stated to clarified which ports should be exposed in more general case.
If you are behind firewall blocking incoming connections to port 9000 while supporting UPnP you can add --enable-upnp
.
To see logs of this containers run:
docker logs -f pulsechain_consensus
Docker Compose geth + Lighthouse
You can used docker-compose
to setup and manage the Docker container. You will need a file named docker-compose.yml
with the following content:
version: '3.4'
services:
pulsechain_execution:
image: registry.gitlab.com/pulsechaincom/go-pulse:latest
tty: true
ports:
- "127.0.0.1:8545:8545/tcp"
- "127.0.0.1:8546:8546/tcp"
- "127.0.0.1:6060:6060/tcp" # if used with --metrics or --pprof
- "30303:30303"
volumes:
- /blockchain:/blockchain
restart: unless-stopped
stop_grace_period: 3m
#oom_kill_disable: true
command:
- --datadir=/blockchain/execution
- --pulsechain-testnet-v4
- --authrpc.jwtsecret=/blockchain/secret/jwt.hex
- --authrpc.addr=pulsechain_execution
- --authrpc.vhosts=pulsechain_execution
- --http
- --http.api=eth,net,web3
- --http.addr=0.0.0.0
- --http.corsdomain=pulsechain_execution
- --http.vhosts=pulsechain_execution
- --ws
- --ws.api=eth,net,web3
- --ws.addr=0.0.0.0
- --metrics
- --metrics.addr=0.0.0.0
- --pprof
- --pprof.addr=0.0.0.0
pulsechain_consensus:
image: registry.gitlab.com/pulsechaincom/lighthouse-pulse
tty: true
ports:
- "9000:9000/tcp"
- "9000:9000/udp"
- "127.0.0.1:5052:5052/tcp"
restart: unless-stopped
depends_on:
- pulsechain_execution
volumes:
- /blockchain:/blockchain
command:
- lighthouse
- beacon_node
- --network=pulsechain_testnet_v4
- --datadir=/blockchain/consensus
- --execution-jwt=/blockchain/secret/jwt.hex
- --execution-endpoint=http://pulsechain_execution:8551
- --checkpoint-sync-url=https://checkpoint.v4.testnet.pulsechain.com
- --http
- --http-address
- 127.0.0.1
To start the container using this Docker Compose script you have to run the following command from within the directory where docker-compose.yml
is located:
docker-compose up -d
The docker-compose tool will print names of container created or started. Note this name for any future actions with this (see below). If your current directory was let’s say pulsechain/
then the container will most likely be named pulsechain_execution_1
and pulsechain_consensus_1
.
To shutdown the container run from within the directory where docker-compose.yml
is located:
docker-componse down
Registering validator
To become a validator you must proceed with register at PulseChain LaunchPad.
docker run -it –rm -v /data/blockchain/pulsechain.secret:/blockchain/secret registry.gitlab.com/pulsechaincom/lighthouse-pulse:latest lighthouse –netwo rk=pulsechain_testnet_v4 account validator import –directory=/blockchain/secret/validator_keys
docker run -it –rm -v /data/blockchain/pulsechain:/blockchain -v /data/blockchain/pulsechain.secret:/blockchain/secret registry.gitlab.com/pulsechaincom/lighthouse-pulse:latest lighthouse –network=pulsechain_testnet_v4 account validator import –directory=/blockchain/secret/validator_keys –datadir /blockchain/