Add a stack to run an Ethereum node #1

Merged
nabarun merged 6 commits from pm-add-eth-stack into main 2024-09-11 04:18:18 +00:00
4 changed files with 73 additions and 21 deletions
Showing only changes of commit 728b789aba - Show all commits

View File

@ -5,9 +5,9 @@ services:
image: ethereum/client-go:alltools-v1.14.8 image: ethereum/client-go:alltools-v1.14.8
environment: environment:
CERC_SCRIPT_DEBUG: ${CERC_SCRIPT_DEBUG} CERC_SCRIPT_DEBUG: ${CERC_SCRIPT_DEBUG}
ETH_DATADIR: "/root/.ethereum"
CERC_NETWORK: ${CERC_NETWORK:-sepolia} CERC_NETWORK: ${CERC_NETWORK:-sepolia}
CERC_ALLOW_UNPROTECTED_TXS: ${CERC_ALLOW_UNPROTECTED_TXS:-false} CERC_ALLOW_UNPROTECTED_TXS: ${CERC_ALLOW_UNPROTECTED_TXS:-false}
CERC_ETH_DATADIR: ${CERC_ETH_DATADIR:-/root/.ethereum}
CERC_GETH_VERBOSITY: ${CERC_GETH_VERBOSITY:-3} CERC_GETH_VERBOSITY: ${CERC_GETH_VERBOSITY:-3}
entrypoint: ["sh", "-c"] entrypoint: ["sh", "-c"]
command: | command: |
@ -35,8 +35,8 @@ services:
CERC_SCRIPT_DEBUG: ${CERC_SCRIPT_DEBUG} CERC_SCRIPT_DEBUG: ${CERC_SCRIPT_DEBUG}
ETH_ENDPOINT: "http://eth-geth:8545" ETH_ENDPOINT: "http://eth-geth:8545"
EXECUTION_ENDPOINT: "http://eth-geth:8551" EXECUTION_ENDPOINT: "http://eth-geth:8551"
LIGHTHOUSE_DATADIR: "/root/.lighthouse"
CERC_NETWORK: ${CERC_NETWORK:-sepolia} CERC_NETWORK: ${CERC_NETWORK:-sepolia}
CERC_LIGHTHOUSE_DATADIR: ${CERC_LIGHTHOUSE_DATADIR:-/root/.lighthouse}
CERC_CHECKPOINT_SYNC_URL: ${CERC_CHECKPOINT_SYNC_URL} CERC_CHECKPOINT_SYNC_URL: ${CERC_CHECKPOINT_SYNC_URL}
CERC_DEBUG_LEVEL: ${CERC_DEBUG_LEVEL:-info} CERC_DEBUG_LEVEL: ${CERC_DEBUG_LEVEL:-info}
command: bash /root/scripts/run-cl.sh command: bash /root/scripts/run-cl.sh
@ -44,13 +44,6 @@ services:
- eth_lighthouse_data:/root/.lighthouse - eth_lighthouse_data:/root/.lighthouse
- eth_secrets:/root/secrets - eth_secrets:/root/secrets
- ../config/eth/run-cl.sh:/root/scripts/run-cl.sh - ../config/eth/run-cl.sh:/root/scripts/run-cl.sh
healthcheck:
# TODO: Update
test: ["CMD", "wget", "--tries=1", "--connect-timeout=1", "--quiet", "-O", "-", "http://localhost:8001/eth/v2/beacon/blocks/head"]
interval: 30s
timeout: 10s
retries: 10
start_period: 30s
ports: ports:
- "8001" - "8001"

View File

@ -8,9 +8,9 @@ fi
echo "Using the following env:" echo "Using the following env:"
echo "CERC_NETWORK: ${CERC_NETWORK}" echo "CERC_NETWORK: ${CERC_NETWORK}"
echo "CERC_LIGHTHOUSE_DATADIR: ${CERC_LIGHTHOUSE_DATADIR}"
echo "CERC_CHECKPOINT_SYNC_URL: ${CERC_CHECKPOINT_SYNC_URL}" echo "CERC_CHECKPOINT_SYNC_URL: ${CERC_CHECKPOINT_SYNC_URL}"
echo "CERC_DEBUG_LEVEL: ${CERC_DEBUG_LEVEL}" echo "CERC_DEBUG_LEVEL: ${CERC_DEBUG_LEVEL}"
echo "LIGHTHOUSE_DATADIR: ${LIGHTHOUSE_DATADIR}"
echo "ETH_ENDPOINT: ${ETH_ENDPOINT}" echo "ETH_ENDPOINT: ${ETH_ENDPOINT}"
echo "EXECUTION_ENDPOINT: ${EXECUTION_ENDPOINT}" echo "EXECUTION_ENDPOINT: ${EXECUTION_ENDPOINT}"
@ -24,16 +24,17 @@ cleanup() {
} }
trap 'cleanup' SIGINT SIGTERM trap 'cleanup' SIGINT SIGTERM
# Create a JWT secret at shared path # Create a JWT secret at shared path if not found
jwtsecret_file_path=/root/secrets/jwtsecret jwtsecret_file_path=/root/secrets/jwtsecret
openssl rand -hex 32 | tr -d "\n" > $jwtsecret_file_path if [ ! -f "$jwtsecret_file_path" ]; then
openssl rand -hex 32 | tr -d "\n" > $jwtsecret_file_path
echo "Using the JWT secret generated at $jwtsecret_file_path" echo "Generated JWT secret at $jwtsecret_file_path"
fi
http_port=8001 http_port=8001
lighthouse bn \ lighthouse bn \
--network $CERC_NETWORK \ --network $CERC_NETWORK \
--datadir $CERC_LIGHTHOUSE_DATADIR/$CERC_NETWORK \ --datadir $LIGHTHOUSE_DATADIR/$CERC_NETWORK \
--execution-endpoint $EXECUTION_ENDPOINT \ --execution-endpoint $EXECUTION_ENDPOINT \
--execution-jwt $jwtsecret_file_path \ --execution-jwt $jwtsecret_file_path \
--checkpoint-sync-url $CERC_CHECKPOINT_SYNC_URL \ --checkpoint-sync-url $CERC_CHECKPOINT_SYNC_URL \

View File

@ -8,8 +8,8 @@ fi
echo "Using the following env:" echo "Using the following env:"
echo "CERC_NETWORK: ${CERC_NETWORK}" echo "CERC_NETWORK: ${CERC_NETWORK}"
echo "CERC_ALLOW_UNPROTECTED_TXS: ${CERC_ALLOW_UNPROTECTED_TXS}" echo "CERC_ALLOW_UNPROTECTED_TXS: ${CERC_ALLOW_UNPROTECTED_TXS}"
echo "CERC_ETH_DATADIR: ${CERC_ETH_DATADIR}"
echo "CERC_GETH_VERBOSITY: ${CERC_GETH_VERBOSITY}" echo "CERC_GETH_VERBOSITY: ${CERC_GETH_VERBOSITY}"
echo "ETH_DATADIR: ${ETH_DATADIR}"
# See https://linuxconfig.org/how-to-propagate-a-signal-to-child-processes-from-a-bash-script # See https://linuxconfig.org/how-to-propagate-a-signal-to-child-processes-from-a-bash-script
cleanup() { cleanup() {
@ -50,7 +50,7 @@ fi
geth \ geth \
${NETWORK_OPT} \ ${NETWORK_OPT} \
--datadir="${CERC_ETH_DATADIR}" \ --datadir="${ETH_DATADIR}" \
--authrpc.addr="0.0.0.0" \ --authrpc.addr="0.0.0.0" \
--authrpc.vhosts="*" \ --authrpc.vhosts="*" \
--authrpc.jwtsecret="$jwtsecret_file_path" \ --authrpc.jwtsecret="$jwtsecret_file_path" \

View File

@ -10,13 +10,27 @@
## Create a deployment ## Create a deployment
* First, create a spec file for the deployment, which will map the stack's ports and volumes to the host: * Create a spec file for the deployment, which will map the stack's ports and volumes to the host:
```bash ```bash
laconic-so --stack ~/cerc/eth-stack/stack-orchestrator/stacks/eth deploy init --output eth-spec.yml laconic-so --stack ~/cerc/eth-stack/stack-orchestrator/stacks/eth deploy init --output eth-spec.yml
``` ```
* Once you've made any needed changes to the spec file, create a deployment from it: * Edit `network` in the spec file to map container ports to host ports as required:
```yml
...
network:
ports:
eth-geth:
- '8545:8545'
- '8546:8546'
- '6060:6060'
eth-lighthouse:
- '8001:8001'
```
* Create a deployment from the spec file:
```bash ```bash
laconic-so --stack ~/cerc/eth-stack/stack-orchestrator/stacks/eth deploy create --spec-file eth-spec.yml --deployment-dir eth-deployment laconic-so --stack ~/cerc/eth-stack/stack-orchestrator/stacks/eth deploy create --spec-file eth-spec.yml --deployment-dir eth-deployment
@ -26,8 +40,29 @@
```bash ```bash
# Optional # Optional
# Allow unprotected txs
CERC_ALLOW_UNPROTECTED_TXS=true # Network to run the ETH node for (default: sepolia)
# (one of mainnet, sepolia, holesky)
CERC_NETWORK=
# Geth options (https://geth.ethereum.org/docs/fundamentals/command-line-options)
# Allow unprotected txs (default: false)
CERC_ALLOW_UNPROTECTED_TXS=
# Verbosity level (default: info)
CERC_GETH_VERBOSITY=
# Lighthouse BN options (https://lighthouse-book.sigmaprime.io/help_bn.html)
# Verbosity level (default: info)
CERC_DEBUG_LEVEL=
# Required
# Beacon node endpoint to use for checkpoint sync
# (https://eth-clients.github.io/checkpoint-sync-endpoints/)
CERC_CHECKPOINT_SYNC_URL=
``` ```
## Start ## Start
@ -38,6 +73,29 @@
laconic-so deployment --dir eth-deployment start laconic-so deployment --dir eth-deployment start
``` ```
## Check status
* To list down and monitor the running containers:
```bash
# With status
docker ps -a
# Follow logs for eth-geth container
laconic-so deployment --dir eth-deployment logs eth-geth -f
# Follow logs for eth-lighthouse container
laconic-so deployment --dir eth-deployment logs eth-lighthouse -f
```
* Once the node has caught up to head, make a request to get the latest block number:
```bash
curl -H "Content-Type: application/json" \
--data '{"jsonrpc":"2.0","method":"eth_blockNumber","params":[],"id":1}' \
http://localhost:8545
```
## Clean up ## Clean up
* To stop all services running in the background, while preserving chain data: * To stop all services running in the background, while preserving chain data: