This repo is no longer maintained, the project migrated to https://github.com/stereum-dev/ethereum2-docker-compose and is now part of the repository there!
This docker-compose suite includes all parts to run and monitor a Prysm Ethereum 2.0 staking node. Please read this README in order to customize it to your needs.
Credits to prysm-grafana-dashboard for providing the dashboards!
Using docker-elk
- geth (beacon conntects to it to see deposits for validators)
- beacon
- validator
- slasher
- prometheus
- grafana
All services are enabled by default.
In case you want to run only beacon & validator (geth, slasher, prometheus, grafana get disabled) move the ./compose-examples/docker-compose.beacon-validator.override.yaml
file in the same folder as your docker-compose.yaml
and rename it to docker-compose.override.yaml
. Read up on docker-compose files & override to customize your setup further.
Using this setup on a raspberry pi is as easy as copying the compose override file from ./compose-examples/docker-compose.arm64.override.yaml
to ./docker-compose.override.yaml
. The override file should then be in the same folder as your docker-compose.override.yaml
:
cp compose-examples/docker-compose.arm64.override.yaml docker-compose.override.yaml
This also disables prometheus and grafana and uses external eth1 node connection (see ./config/beacon-no-geth.yaml
for changing the endpoint).
To run with Spadina testnet copy ./compose-examples/docker-compose.spadina.override.yaml
in the same folder as your docker-compose.yaml
and rename it to docker-compose.override.yaml
.
To run with Zinken testnet copy ./compose-examples/docker-compose.zinken.override.yaml
in the same folder as your docker-compose.yaml
and rename it to docker-compose.override.yaml
.
Thanks to @danbryan for this contribution!
Configuration files are located in the folder ./config
. To gain a better connectivity for your beacon node you should specifiy your public ip and/or your dns name in ./config/beacon.yaml
. Follow the guide Improve Peer-to-Peer Connectivity.
Please complete the steps on launchpad and store the generated files of ~/eth2.0-deposit-cli/validator_keys
in ./launchpad/eth2.0-deposit-cli/validator_keys
. The necessary directories need to be created. Please create the directories ./validator/wallets
and put your wallet password in ./validator/passwords/wallet-password
.
- Generate your validator(s) using launchpad and complete the process
- Copy your generated validator(s) from
~/eth2.0-deposit-cli/validator_keys
to./launchpad/eth2.0-deposit-cli/validator_keys
- Run
docker-compose -f create-account.yaml run validator-import-launchpad
and use the same password as in the generation of the validator(s)
You can repeat step 2 & 3 as often as you like, make sure to restart your validator to make it notice your new accounts!
Run with (as deamon with "-d")
docker-compose up -d
or run only certain services (in this case only beacon and validator)
docker-compose up -d beacon validator
Stop services (or everything) like this
docker-compose stop validator slasher
Shut down your services (or everything) like this:
docker-compose down
Please note: This will also erase your logs, they are stored with your containers and will be deleted as well.
Docker takes care of log files and log file rotation as well as limit (set to 10x100mb log files for each service). View logs of a certain service (in this case beacon, only the last 100 lines)
docker-compose logs --tail=100 beacon
Runs on http://localhost:9090, scrapes data of beacon, validator and slasher.
Grafana listens on http://localhost:3000 and uses the data provided by prometheus service.
Login with username admin
and password admin
(Grafana defaults), data source to Prometheus is already established and dashboards installed.
To aggregate and display logs with ELK-Stack use docker-elk and easy cluster/standalone setup with ansible-elk.
My docker-compose
command doesn't work (e. g. ERROR: Version in "./docker-compose.yaml" is unsupported.
)
Most linux distributions (including Ubuntu) don't serve recent docker-compose versions in their package management. You can install a compatible version by following official docker.io documentation.
E. g. error messages like this:
WARN roughtime: Roughtime reports your clock is off by more than 2 seconds offset=4h0m0.345549475s
Make sure the OS' clock is synced. For Windows 10 and its subsystem linux might run on different times, to check this run wsl
and then date
(may differ by the OS you have installed).
Ask google on how to get your OS' time synced again.
There is an excellent short article about how to install docker and docker-compose on raspberry pi, you can also use google to find another tutorial for it.
Edit the line with http-web3provider
in ./config/beacon.yaml and set your Ethereum 1 node URL, e. g. use it with Infura.io and make it look like this: http-web3provider: https://goerli.infura.io:443/v3/put-your-infura-id-here
.
This software is provided under MIT license and therefore freely usable without restrictions. Dontations are always welcome:
ETH - 0xA1DDc7ed6E7b9179C68cDEE24a5e47dE930061eE
BTC - 39n4LUxbcCfJvBGvFVVwQQkGxSJ44JRYV7