2019-09-10 22:13:27 +00:00
|
|
|
import
|
2019-10-29 03:58:31 +00:00
|
|
|
strformat, ospaths
|
2019-09-10 22:13:27 +00:00
|
|
|
|
|
|
|
var
|
|
|
|
serverCount = 10
|
|
|
|
instancesCount = 2
|
|
|
|
|
|
|
|
totalValidators = 1000
|
|
|
|
userValidators = 200
|
|
|
|
|
|
|
|
systemValidators = totalValidators - userValidators
|
|
|
|
validatorsPerServer = systemValidators div serverCount
|
|
|
|
validatorsPerNode = validatorsPerServer div instancesCount
|
|
|
|
|
|
|
|
if paramCount() < 4:
|
|
|
|
echo "Usage: nim --verbosity:0 manage_testnet_hosts.nim NETWORK COMMAND"
|
|
|
|
quit 1
|
|
|
|
|
|
|
|
let
|
|
|
|
network = paramStr(3)
|
|
|
|
cmd = paramStr(4)
|
|
|
|
|
|
|
|
iterator nodes: tuple[server, container: string, firstValidator, lastValidator: int] =
|
|
|
|
for i in 0 ..< serverCount:
|
|
|
|
let
|
|
|
|
baseIdx = userValidators + i * validatorsPerServer
|
|
|
|
nodeName = if i == 0: "master-01" else: &"node-0{i}"
|
|
|
|
server = &"{nodeName}.do-ams3.nimbus.test.statusim.net"
|
|
|
|
|
|
|
|
for j in 1 .. instancesCount:
|
|
|
|
let firstIdx = baseIdx + j * validatorsPerNode
|
|
|
|
let lastIdx = firstIdx + validatorsPerNode - 1
|
|
|
|
yield (server, &"beacon-node-{network}-{j}", firstIdx, lastIdx)
|
|
|
|
|
|
|
|
case cmd
|
|
|
|
of "restart-nodes":
|
|
|
|
for n in nodes():
|
|
|
|
echo &"ssh {n.server} docker restart {n.container}"
|
2019-10-29 03:58:31 +00:00
|
|
|
|
2019-09-10 22:13:27 +00:00
|
|
|
of "redist-validators":
|
2019-10-29 03:58:31 +00:00
|
|
|
let depositsDir = paramStr(5)
|
2019-09-10 22:13:27 +00:00
|
|
|
for n in nodes():
|
2019-10-29 03:58:31 +00:00
|
|
|
var keysList = ""
|
|
|
|
for i in n.firstValidator..n.lastValidator:
|
|
|
|
let validatorKey = fmt"v{i:07}.privkey"
|
|
|
|
keysList.add " "
|
|
|
|
keysList.add depositsDir / validatorKey
|
|
|
|
|
2019-09-10 22:13:27 +00:00
|
|
|
let dockerPath = &"/docker/{n.container}/data/BeaconNode/{network}"
|
2019-10-29 03:58:31 +00:00
|
|
|
echo &"rsync {keysList} {n.server}:/tmp/nimbus-keys"
|
2019-09-10 22:13:27 +00:00
|
|
|
echo &"ssh {n.server} 'sudo mkdir -p {dockerPath}/validators && sudo rm -f {dockerPath}/validators/* && " &
|
2019-10-29 03:58:31 +00:00
|
|
|
&"sudo mv /tmp/nimbus-keys/* {dockerPath}/validators/ && " &
|
2019-09-10 22:13:27 +00:00
|
|
|
&"sudo chown dockremap:docker -R {dockerPath}'"
|
|
|
|
else:
|
|
|
|
echo "Unrecognized command: ", cmd
|