forked from eth-educators/eth-docker
-
Notifications
You must be signed in to change notification settings - Fork 0
/
nimbus-cl-only.yml
112 lines (108 loc) · 3.55 KB
/
nimbus-cl-only.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
version: "3.9"
x-logging: &logging
logging:
driver: json-file
options:
max-size: 100m
max-file: "3"
tag: '{{.ImageName}}|{{.Name}}|{{.ImageFullID}}|{{.FullID}}'
x-build: &nimbus-build
context: ./nimbus
dockerfile: ${NIM_DOCKERFILE}
args:
- BUILD_TARGET=${NIM_SRC_BUILD_TARGET:-'$(git describe --tags $(git rev-list --tags --max-count=1))'}
- SRC_REPO=${NIM_SRC_REPO:-https://github.com/status-im/nimbus-eth2}
- DOCKER_TAG=${NIM_DOCKER_TAG:-multiarch-latest}
- DOCKER_VC_TAG=${NIM_DOCKER_VC_TAG:-multiarch-latest}
- DOCKER_REPO=${NIM_DOCKER_REPO:-statusim/nimbus-eth2}
- DOCKER_VC_REPO=${NIM_DOCKER_VC_REPO:-statusim/nimbus-validator-client}
services:
consensus:
restart: "unless-stopped"
build:
target: consensus
<<: *nimbus-build
image: nimbus:local
user: user
stop_grace_period: 1m
volumes:
- nimbus-consensus-data:/var/lib/nimbus
- /etc/localtime:/etc/localtime:ro
- jwtsecret:/var/lib/nimbus/ee-secret
environment:
- RAPID_SYNC_URL=${RAPID_SYNC_URL}
- NETWORK=${NETWORK}
- JWT_SECRET=${JWT_SECRET}
- MEV_BOOST=${MEV_BOOST}
- MEV_NODE=${MEV_NODE}
- LOG_LEVEL=${LOG_LEVEL}
- DOPPELGANGER=false
- CL_EXTRAS=${CL_EXTRAS:-}
- VC_EXTRAS=
- ARCHIVE_NODE=${ARCHIVE_NODE:-}
- GRAFFITI=${GRAFFITI:-}
- DEFAULT_GRAFFITI=true
- WEB3SIGNER=false
- EMBEDDED_VC=false
ports:
- ${HOST_IP:-}${CL_P2P_PORT:-9000}:${CL_P2P_PORT:-9000}/tcp
- ${HOST_IP:-}${CL_P2P_PORT:-9000}:${CL_P2P_PORT:-9000}/udp
networks:
default:
aliases:
- eth2
<<: *logging
entrypoint:
- docker-entrypoint.sh
- /usr/local/bin/nimbus_beacon_node
- --data-dir=/var/lib/nimbus
- --non-interactive
- --status-bar=false
- --tcp-port=${CL_P2P_PORT:-9000}
- --udp-port=${CL_P2P_PORT:-9000}
- --max-peers=${CL_MAX_PEER_COUNT:-160}
- --el=${EL_NODE}
- --jwt-secret=/var/lib/nimbus/ee-secret/jwtsecret
- --rest
- --rest-address=0.0.0.0
- --rest-port=${CL_REST_PORT:-5052}
- --enr-auto-update=true
- --metrics
- --metrics-port=8008
- --metrics-address=0.0.0.0
- --suggested-fee-recipient=${FEE_RECIPIENT}
- --in-process-validators=false
labels:
- traefik.enable=true
- traefik.http.routers.${CL_HOST:-cl}.service=${CL_HOST:-cl}
- traefik.http.routers.${CL_HOST:-cl}.entrypoints=websecure
- traefik.http.routers.${CL_HOST:-cl}.rule=Host(`${CL_HOST:-cl}.${DOMAIN}`)
- traefik.http.routers.${CL_HOST:-cl}.tls.certresolver=letsencrypt
- traefik.http.routers.${CL_HOST:-cl}lb.service=${CL_HOST:-cl}
- traefik.http.routers.${CL_HOST:-cl}lb.entrypoints=websecure
- traefik.http.routers.${CL_HOST:-cl}lb.rule=Host(`${CL_LB:-cl-lb}.${DOMAIN}`)
- traefik.http.routers.${CL_HOST:-cl}lb.tls.certresolver=letsencrypt
- traefik.http.services.${CL_HOST:-cl}.loadbalancer.server.port=${CL_REST_PORT:-5052}
# Uses keystore-m file and CL, so does belong here
validator-exit:
profiles: ["tools"]
restart: "no"
build:
target: consensus
<<: *nimbus-build
image: nimbus:local
user: root
volumes:
- /etc/localtime:/etc/localtime:ro
- ./.eth/validator_keys:/validator_keys
entrypoint:
- validator-exit.sh
- /usr/local/bin/nimbus_beacon_node
- --log-level=${LOG_LEVEL}
- deposits
- exit
- --rest-url=http://consensus:5052
- --validator=
volumes:
nimbus-consensus-data:
jwtsecret: