mirror of
https://github.com/status-im/nimbus-eth2.git
synced 2025-01-16 01:27:01 +00:00
ef2b434ec9
Local testnet simulation currently waits 5 seconds when starting each individual Geth instance. Waiting a shorter amount saves almost a minute per minimum + mainnet CI finalization job. Measured startup times per Geth: Linux ~100ms, macOS Intel ~300ms.
60 lines
2.3 KiB
Bash
Executable File
60 lines
2.3 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
|
|
set -euo pipefail
|
|
|
|
BASEDIR="$(dirname "${BASH_SOURCE[0]}")"
|
|
|
|
. "${BASEDIR}/geth_vars.sh"
|
|
|
|
#These are used in the caller script
|
|
GETH_ENODES=()
|
|
GETH_HTTP_PORTS=()
|
|
GETH_NET_PORTS=()
|
|
GETH_WS_PORTS=()
|
|
GETH_RPC_PORTS=()
|
|
GETH_DATA_DIRS=()
|
|
|
|
log "Using ${GETH_BINARY}"
|
|
|
|
for GETH_NUM_NODE in $(seq 0 $(( GETH_NUM_NODES - 1 ))); do
|
|
GETH_NET_PORT=$(( GETH_NUM_NODE * GETH_PORT_OFFSET + GETH_BASE_NET_PORT ))
|
|
GETH_HTTP_PORT=$(( GETH_NUM_NODE * GETH_PORT_OFFSET + GETH_BASE_HTTP_PORT ))
|
|
GETH_WS_PORT=$(( GETH_NUM_NODE * GETH_PORT_OFFSET + GETH_BASE_WS_PORT ))
|
|
GETH_AUTH_RPC_PORT=$(( GETH_NUM_NODE * GETH_PORT_OFFSET + GETH_BASE_AUTH_RPC_PORT ))
|
|
log "Starting geth node ${GETH_NUM_NODE} on net port ${GETH_NET_PORT} HTTP port ${GETH_HTTP_PORT} WS port ${GETH_WS_PORT}"
|
|
GETHDATADIR=$(mktemp -d "${DATA_DIR}"/geth-data-XXX)
|
|
GETH_DATA_DIRS+=(${GETHDATADIR})
|
|
openssl rand -hex 32 | tr -d "\n" > "${GETHDATADIR}/jwtsecret"
|
|
${GETH_BINARY} --http --ws -http.api "engine" --datadir "${GETHDATADIR}" init "${GENESISJSON}"
|
|
${GETH_BINARY} --http --ws --http.corsdomain '*' --http.api "eth,net,engine" -ws.api "eth,net,engine" --datadir "${GETHDATADIR}" ${DISCOVER} --port ${GETH_NET_PORT} --http.port ${GETH_HTTP_PORT} --ws.port ${GETH_WS_PORT} --authrpc.port ${GETH_AUTH_RPC_PORT} --authrpc.jwtsecret "${GETHDATADIR}/jwtsecret" &> "${DATA_DIR}/geth-log${GETH_NUM_NODE}.txt" &
|
|
GETH_RETRY=0
|
|
while :; do
|
|
if [[ -S "${GETHDATADIR}/geth.ipc" ]]; then
|
|
echo "Geth ${GETH_NUM_NODE} started in $(( GETH_RETRY * 100 ))ms"
|
|
break
|
|
fi
|
|
if (( ++GETH_RETRY >= 300 )); then
|
|
echo "Geth ${GETH_NUM_NODE} failed to start"
|
|
exit 1
|
|
fi
|
|
sleep 0.1
|
|
done
|
|
NODE_ID=$(${GETH_BINARY} attach --datadir "${GETHDATADIR}" --exec admin.nodeInfo.enode)
|
|
GETH_ENODES+=("${NODE_ID}")
|
|
GETH_HTTP_PORTS+=("${GETH_HTTP_PORT}")
|
|
GETH_NET_PORTS+=("${GETH_NET_PORT}")
|
|
GETH_WS_PORTS+=("${GETH_WS_PORT}")
|
|
GETH_RPC_PORTS+=("${GETH_AUTH_RPC_PORT}")
|
|
done
|
|
|
|
#Add all nodes as peers
|
|
for dir in "${GETH_DATA_DIRS[@]}"
|
|
do
|
|
for enode in "${GETH_ENODES[@]}"
|
|
do
|
|
${GETH_BINARY} attach --datadir "${dir}" --exec "admin.addPeer(${enode})"
|
|
done
|
|
done
|
|
|
|
log "GETH HTTP Ports: ${GETH_HTTP_PORTS[*]}"
|