-
Notifications
You must be signed in to change notification settings - Fork 20
Expand file tree
/
Copy pathvalues.yaml
More file actions
250 lines (219 loc) · 7.96 KB
/
values.yaml
File metadata and controls
250 lines (219 loc) · 7.96 KB
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
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
genesis:
accountGeneration:
enabled: false
count: 10
balance: "0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFD4A51000FDA0FFFF"
password: "password123"
timestamp: "0x0"
url: "https://storage.googleapis.com/devnet-artifacts/devnet-genesis/genesis.json"
erigon:
networkId: 141414
datadir: "/data/erigon"
ports:
http: 8545
ws: 8546
authrpc: 8551
metrics: 6061
privateApi: 9095
p2p: 30303
api:
http:
enabled: true
addr: "0.0.0.0"
vhosts: "*"
corsdomain: "*"
api: "eth,erigon,engine,net,web3,txpool"
ws:
enabled: true
addr: "0.0.0.0"
vhosts: "*"
metrics:
enabled: true
addr: "0.0.0.0"
zeroFeeTxList:
- "0x421657a89f467ac04c542e46645a7752e199b5e6" # Contracts Deployer Keystore
- "0x1c533735c11dd317bc816629f86e00f479d097a3" # Oracle Keystore
#- "0x929f3b326ea399cb953c18854733d6b894b9e819" # Bridge Relayer Keystore
pruneMode: "archive"
nodiscover: true
# Additional arguments to pass to erigon
extraArgs:
common: [] # Args applied to both leader and follower
leader:
- "--port=30303"
follower:
- "--port=30304"
- "--staticpeers=enode://674ce5dc5c6862ed6a91b32bbd196753a3ab329032a9a549a0cb3a20ab97da1ccae40ff6ef1bbab6e8bba62fc5924b9346354c5d63a5874522a2bc884c24a098@erigon-snode-leader-erigon.default.svc.cluster.local:30303"
- "--trustedpeers=enode://674ce5dc5c6862ed6a91b32bbd196753a3ab329032a9a549a0cb3a20ab97da1ccae40ff6ef1bbab6e8bba62fc5924b9346354c5d63a5874522a2bc884c24a098@erigon-snode-leader-erigon.default.svc.cluster.local:30303"
consensus:
leader:
# Leader node configuration
instanceId: "snode-leader"
apiAddr: ":9090" # Address for member node API endpoint
healthAddr: ":8080" # Address for health check endpoint
priorityFeeRecipient: "0xcEc94aeB187321262BA8Ae5BB0A9D79EAd56da92" # Ethereum address for receiving priority fees
nonAuthRpcUrl: "http://localhost:8545" # Non-authenticated Ethereum RPC URL
# JWT secret for leader's Ethereum Execution client Engine API
jwtSecret: "32c2902cc88b19b1c775ffef7e67673f296beb2e610f93230b40e5ef822ae9d4"
# EVM build configuration
evmBuildDelay: "1ms" # Delay after initiating payload construction before calling getPayload
evmBuildDelayEmptyBlock: "1m0s" # Minimum time since last block to build an empty block
txPoolPollingInterval: "5ms" # Wait interval for polling the tx pool while there are no pending transactions
# Database configuration (optional for leader)
postgresDb:
dsn: "postgres://mev_commit_consensus:FlYvDD9hwHwHn6c0ncXpEKXA6xefcZcJVqEjk7RSEeCMeZQbRr69p2sN6bjcQGi2@mev-commit-consensus-postgresql.default.svc.cluster.local:5432/mev_commit_consensus?sslmode=disable" # PostgreSQL DSN - if empty, saving to DB is disabled
# Logging configuration
logLevel: "info" # Log level ('debug', 'info', 'warn', 'error')
logFmt: "text" # Log format ('text' or 'json')
logTags: "" # Comma-separated <name:value> log tags (e.g., env:prod,service:snode)
# Additional arguments
extraArgs: []
follower:
enabled: true
replicaCount: 1
# Follower node configuration
instanceId: "snode-follower"
healthAddr: ":8080" # Address for health check endpoint
# JWT secret for follower's Ethereum Execution client Engine API
jwtSecret: "13373d9a0257983ad150392d7ddb2f9172c9396b4c450e26af469d123c7aaa5c"
# Database configuration (REQUIRED for followers)
postgresDb:
dsn: "postgres://mev_commit_consensus:FlYvDD9hwHwHn6c0ncXpEKXA6xefcZcJVqEjk7RSEeCMeZQbRr69p2sN6bjcQGi2@mev-commit-consensus-postgresql.default.svc.cluster.local:5432/mev_commit_consensus?sslmode=disable" # REQUIRED: PostgreSQL DSN for follower
# Sync configuration
syncBatchSize: 100 # Number of payloads per request to the EL during sync
# Logging configuration
logLevel: "info" # Log level ('debug', 'info', 'warn', 'error')
logFmt: "text" # Log format ('text' or 'json')
logTags: "" # Comma-separated <name:value> log tags (e.g., env:prod,service:snode)
# Additional arguments
extraArgs: []
image:
erigon:
repository: primev/primev
tag: erigon-snode-v3.0.7-ms-patch
pullPolicy: IfNotPresent
snode:
repository: primev/primev
tag: snode-consensus-v3.0.7-retry-fix
pullPolicy: IfNotPresent
storage:
size: 100Gi
storageClassName: premium-rwo
accessMode: ReadWriteOnce
security:
runAsUser: 0
runAsGroup: 0
runAsNonRoot: false
fsGroup: 0
replicaCount: 1
terminationGracePeriodSeconds: 300
# Resource requests and limits
resources:
erigon:
requests:
cpu: "100m"
memory: "500Mi"
limits:
cpu: "6000m"
memory: "16Gi"
snode:
requests:
cpu: "100m"
memory: "100Mi"
limits:
cpu: "6000m"
memory: "16Gi"
# Init container resources
initContainerResources:
requests:
cpu: "50m"
memory: "100Mi"
limits:
cpu: "1000m"
memory: "1Gi"
service:
erigon:
type: LoadBalancer
ports:
http: 8545
ws: 8546
authrpc: 8551
metrics: 6061
customSelector: {}
snode:
type: ClusterIP
ports:
api: 9090
health: 8080
customSelector: {}
nodeSelector: {}
tolerations: []
affinity: {}
topologySpreadConstraints: []
# Additional labels for StatefulSet
additionalLabels: {}
ingress:
enabled: true
className: "nginx"
# Leader RPC Configuration
rpc:
host: dev-test.mev-commit.xyz
path: /
pathType: Prefix
annotations:
nginx.ingress.kubernetes.io/backend-protocol: "HTTP"
nginx.ingress.kubernetes.io/force-ssl-redirect: "true"
nginx.ingress.kubernetes.io/proxy-body-size: "0"
nginx.ingress.kubernetes.io/proxy-read-timeout: "1200"
nginx.ingress.kubernetes.io/proxy-send-timeout: "1200"
nginx.ingress.kubernetes.io/ssl-redirect: "true"
# Leader WebSocket Configuration
websocket:
host: dev-test-wss.mev-commit.xyz
path: /
pathType: Prefix
annotations:
nginx.ingress.kubernetes.io/backend-protocol: "HTTP"
nginx.ingress.kubernetes.io/force-ssl-redirect: "true"
nginx.ingress.kubernetes.io/proxy-body-size: "0"
nginx.ingress.kubernetes.io/proxy-read-timeout: "36h00"
nginx.ingress.kubernetes.io/proxy-send-timeout: "3600"
nginx.ingress.kubernetes.io/ssl-redirect: "true"
nginx.ingress.kubernetes.io/proxy-http-version: "1.1"
nginx.ingress.kubernetes.io/proxy-set-headers: |
Connection "upgrade"
Upgrade $http_upgrade
# TLS Configuration
tls:
secretName: mev-commit-tls
# Follower ingress (when follower.enabled=true)
follower:
enabled: false # Set to true to expose follower via ingress
rpc:
host: "test-dev.mev-commit.xyz"
path: /
pathType: Prefix
annotations:
nginx.ingress.kubernetes.io/backend-protocol: "HTTP"
nginx.ingress.kubernetes.io/force-ssl-redirect: "true"
nginx.ingress.kubernetes.io/proxy-body-size: "0"
nginx.ingress.kubernetes.io/proxy-read-timeout: "1200"
nginx.ingress.kubernetes.io/proxy-send-timeout: "1200"
nginx.ingress.kubernetes.io/ssl-redirect: "true"
websocket:
host: "test-dev.mev-commit.xyz"
path: /
pathType: Prefix
annotations:
nginx.ingress.kubernetes.io/backend-protocol: "HTTP"
nginx.ingress.kubernetes.io/force-ssl-redirect: "true"
nginx.ingress.kubernetes.io/proxy-body-size: "0"
nginx.ingress.kubernetes.io/proxy-read-timeout: "36h00"
nginx.ingress.kubernetes.io/proxy-send-timeout: "3600"
nginx.ingress.kubernetes.io/ssl-redirect: "true"
nginx.ingress.kubernetes.io/proxy-http-version: "1.1"
nginx.ingress.kubernetes.io/proxy-set-headers: |
Connection "upgrade"
Upgrade $http_upgrade
tls:
secretName: "mev-commit-tls"