2019-09-10 18:13:27 -04:00
|
|
|
import
|
2019-10-29 15:41:10 +02:00
|
|
|
strformat, ospaths, confutils
|
|
|
|
|
|
|
|
type
|
|
|
|
Command = enum
|
|
|
|
restart_nodes
|
2019-11-05 13:00:11 +00:00
|
|
|
reset_network
|
2019-10-29 15:41:10 +02:00
|
|
|
|
|
|
|
CliConfig = object
|
|
|
|
network: string
|
|
|
|
|
|
|
|
case cmd {.command.}: Command
|
|
|
|
of restart_nodes:
|
|
|
|
discard
|
|
|
|
|
2019-11-05 13:00:11 +00:00
|
|
|
of reset_network:
|
2019-10-29 15:41:10 +02:00
|
|
|
depositsDir {.
|
2019-11-05 13:00:11 +00:00
|
|
|
defaultValue: "deposits"
|
2019-11-11 14:43:12 +00:00
|
|
|
name: "deposits-dir" }: string
|
2019-11-05 13:00:11 +00:00
|
|
|
|
2019-10-29 15:41:10 +02:00
|
|
|
networkDataDir {.
|
2019-11-05 13:00:11 +00:00
|
|
|
defaultValue: "data"
|
2019-11-11 14:43:12 +00:00
|
|
|
name: "network-data-dir" }: string
|
2019-11-05 13:00:11 +00:00
|
|
|
|
2019-10-29 15:41:10 +02:00
|
|
|
totalValidators {.
|
2019-11-11 14:43:12 +00:00
|
|
|
name: "total-validators" }: int
|
2019-11-05 13:00:11 +00:00
|
|
|
|
2019-10-29 15:41:10 +02:00
|
|
|
totalUserValidators {.
|
2019-11-05 13:00:11 +00:00
|
|
|
defaultValue: 0
|
2019-11-11 14:43:12 +00:00
|
|
|
name: "user-validators" }: int
|
2019-10-29 15:41:10 +02:00
|
|
|
|
2019-11-12 12:14:55 +00:00
|
|
|
Node = object
|
|
|
|
id: int
|
|
|
|
server: string
|
|
|
|
container: string
|
|
|
|
|
2019-10-29 15:41:10 +02:00
|
|
|
var conf = load CliConfig
|
2019-09-10 18:13:27 -04:00
|
|
|
|
|
|
|
var
|
|
|
|
serverCount = 10
|
|
|
|
instancesCount = 2
|
2019-11-05 13:00:11 +00:00
|
|
|
|
|
|
|
proc findOrDefault[K, V](tupleList: openarray[(K, V)], key: K, default: V): V =
|
|
|
|
for t in tupleList:
|
|
|
|
if t[0] == key:
|
|
|
|
return t[1]
|
|
|
|
|
|
|
|
return default
|
|
|
|
|
2019-11-12 12:14:55 +00:00
|
|
|
iterator nodes: Node =
|
2019-09-10 18:13:27 -04:00
|
|
|
for i in 0 ..< serverCount:
|
|
|
|
let
|
2019-11-12 12:14:55 +00:00
|
|
|
serverShortName = if i == 0: "master-01" else: &"node-0{i}"
|
|
|
|
server = &"{serverShortName}.do-ams3.nimbus.test.statusim.net"
|
2019-09-10 18:13:27 -04:00
|
|
|
|
2019-10-29 15:41:10 +02:00
|
|
|
for j in 0 ..< instancesCount:
|
2019-11-12 12:14:55 +00:00
|
|
|
yield Node(id: i*instancesCount + j,
|
|
|
|
server: server,
|
|
|
|
container: &"beacon-node-{conf.network}-{j+1}")
|
|
|
|
|
|
|
|
iterator validatorAssignments: tuple[node: Node; firstValidator, lastValidator: int] =
|
|
|
|
let
|
|
|
|
systemValidators = conf.totalValidators - conf.totalUserValidators
|
|
|
|
|
|
|
|
defaultValidatorAssignment = proc (nodeIdx: int): int =
|
|
|
|
(systemValidators div serverCount) div instancesCount
|
|
|
|
|
|
|
|
customValidatorAssignments = {
|
|
|
|
# This is used just to force the correct type of the table
|
|
|
|
"default": defaultValidatorAssignment
|
|
|
|
,
|
|
|
|
"testnet0": proc (nodeIdx: int): int =
|
|
|
|
if nodeidx < 4:
|
|
|
|
systemValidators div 4
|
|
|
|
else:
|
|
|
|
0
|
|
|
|
,
|
|
|
|
"testnet1": proc (nodeIdx: int): int =
|
|
|
|
if nodeIdx == 0: systemValidators
|
|
|
|
else: 0
|
|
|
|
}
|
2019-11-05 13:00:11 +00:00
|
|
|
|
2019-11-12 12:14:55 +00:00
|
|
|
var nextValidatorIdx = conf.totalUserValidators
|
|
|
|
for node in nodes():
|
|
|
|
let
|
|
|
|
validatorAssignmentFn = customValidatorAssignments.findOrDefault(
|
|
|
|
conf.network, defaultValidatorAssignment)
|
|
|
|
nodeValidatorCount = validatorAssignmentFn(node.id)
|
2019-11-05 13:00:11 +00:00
|
|
|
|
2019-11-12 12:14:55 +00:00
|
|
|
yield (node,
|
|
|
|
nextValidatorIdx,
|
|
|
|
nextValidatorIdx + nodeValidatorCount)
|
|
|
|
|
|
|
|
inc nextValidatorIdx, nodeValidatorCount
|
2019-09-10 18:13:27 -04:00
|
|
|
|
2019-10-29 15:41:10 +02:00
|
|
|
case conf.cmd
|
|
|
|
of restart_nodes:
|
2019-09-10 18:13:27 -04:00
|
|
|
for n in nodes():
|
|
|
|
echo &"ssh {n.server} docker restart {n.container}"
|
2019-10-29 05:58:31 +02:00
|
|
|
|
2019-11-05 13:00:11 +00:00
|
|
|
of reset_network:
|
2019-11-12 12:14:55 +00:00
|
|
|
for n, firstValidator, lastValidator in validatorAssignments():
|
2019-10-29 15:41:10 +02:00
|
|
|
var
|
|
|
|
keysList = ""
|
|
|
|
networkDataFiles = conf.networkDataDir & "/{genesis.ssz,bootstrap_nodes.txt}"
|
|
|
|
|
2019-11-12 12:14:55 +00:00
|
|
|
for i in firstValidator ..< lastValidator:
|
2019-10-29 05:58:31 +02:00
|
|
|
let validatorKey = fmt"v{i:07}.privkey"
|
|
|
|
keysList.add " "
|
2019-10-29 15:41:10 +02:00
|
|
|
keysList.add conf.depositsDir / validatorKey
|
2019-10-29 05:58:31 +02:00
|
|
|
|
2019-10-29 18:35:21 +02:00
|
|
|
let dockerPath = &"/docker/{n.container}/data/BeaconNode"
|
2019-11-12 12:14:55 +00:00
|
|
|
echo &"echo Syncing {lastValidator - firstValidator} keys starting from {firstValidator} to container {n.container}@{n.server} ... && \\"
|
2019-11-05 00:41:12 +00:00
|
|
|
echo &" ssh {n.server} 'sudo rm -rf /tmp/nimbus && mkdir -p /tmp/nimbus/' && \\"
|
2019-10-29 15:41:10 +02:00
|
|
|
echo &" rsync {networkDataFiles} {n.server}:/tmp/nimbus/net-data/ && \\"
|
2019-11-05 00:41:12 +00:00
|
|
|
if keysList.len > 0: echo &" rsync {keysList} {n.server}:/tmp/nimbus/keys/ && \\"
|
2019-11-05 13:00:11 +00:00
|
|
|
|
|
|
|
echo &" ssh {n.server} 'sudo docker container stop {n.container} && " &
|
|
|
|
&"sudo mkdir -p {dockerPath}/validators && " &
|
2019-11-05 17:33:06 +02:00
|
|
|
&"sudo rm -rf {dockerPath}/validators/* && " &
|
|
|
|
&"sudo rm -rf {dockerPath}/db && " &
|
2019-11-05 00:41:12 +00:00
|
|
|
(if keysList.len > 0: &"sudo mv /tmp/nimbus/keys/* {dockerPath}/validators/ && " else: "") &
|
2019-10-29 15:41:10 +02:00
|
|
|
&"sudo mv /tmp/nimbus/net-data/* {dockerPath}/ && " &
|
2019-09-10 18:13:27 -04:00
|
|
|
&"sudo chown dockremap:docker -R {dockerPath}'"
|
2019-10-29 15:41:10 +02:00
|
|
|
|