forked from cerc-io/stack-orchestrator
3130af1615
* Use mounted volumes for data in geth nodes * Use mounted volumes for data in lighthouse nodes * Avoid resetting genesis time in a lighthouse node on restart * Mount parent datadir for lighthouse nodes * Trap signals on shutdown and clean up in lighthouse nodes * Allow stalled sync in lighthouse beacon nodes * Gracefully shutdown geth nodes * Add clean up instructions * Gracefully shutdown lighthouse boot node
130 lines
4.0 KiB
Bash
Executable File
130 lines
4.0 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
if [ -n "$CERC_SCRIPT_DEBUG" ]; then
|
|
set -x
|
|
fi
|
|
|
|
ETHERBASE=`cat /opt/testnet/build/el/accounts.csv | head -1 | cut -d',' -f2`
|
|
NETWORK_ID=`cat /opt/testnet/el/el-config.yaml | grep 'chain_id' | awk '{ print $2 }'`
|
|
NETRESTRICT=`ip addr | grep inet | grep -v '127.0' | awk '{print $2}'`
|
|
|
|
HOME_DIR=`pwd`
|
|
cd /opt/testnet/build/el
|
|
python3 -m http.server 9898 &
|
|
cd $HOME_DIR
|
|
|
|
START_CMD="geth"
|
|
if [ "true" == "$CERC_REMOTE_DEBUG" ] && [ -x "/usr/local/bin/dlv" ]; then
|
|
START_CMD="/usr/local/bin/dlv --listen=:40000 --headless=true --api-version=2 --accept-multiclient exec /usr/local/bin/geth --continue --"
|
|
fi
|
|
|
|
# See https://linuxconfig.org/how-to-propagate-a-signal-to-child-processes-from-a-bash-script
|
|
cleanup() {
|
|
echo "Signal received, cleaning up..."
|
|
|
|
# Kill the child process first (CERC_REMOTE_DEBUG=true uses dlv which starts geth as a child process)
|
|
pkill -P ${geth_pid}
|
|
sleep 2
|
|
kill $(jobs -p)
|
|
|
|
wait
|
|
echo "Done"
|
|
}
|
|
trap 'cleanup' SIGINT SIGTERM
|
|
|
|
if [ "true" == "$RUN_BOOTNODE" ]; then
|
|
$START_CMD \
|
|
--datadir=~/ethdata \
|
|
--nodekeyhex="${BOOTNODE_KEY}" \
|
|
--nodiscover \
|
|
--ipcdisable \
|
|
--networkid=${NETWORK_ID} \
|
|
--netrestrict="${NETRESTRICT}" \
|
|
&
|
|
|
|
geth_pid=$!
|
|
else
|
|
cd /opt/testnet/accounts
|
|
./import_keys.sh
|
|
|
|
echo -n "$JWT" > /opt/testnet/build/el/jwtsecret
|
|
|
|
if [ "$CERC_RUN_STATEDIFF" == "detect" ] && [ -n "$CERC_STATEDIFF_DB_HOST" ]; then
|
|
dig_result=$(dig $CERC_STATEDIFF_DB_HOST +short)
|
|
dig_status_code=$?
|
|
if [[ $dig_status_code = 0 && -n $dig_result ]]; then
|
|
echo "Statediff DB at $CERC_STATEDIFF_DB_HOST"
|
|
CERC_RUN_STATEDIFF="true"
|
|
else
|
|
echo "No statediff DB available."
|
|
CERC_RUN_STATEDIFF="false"
|
|
fi
|
|
fi
|
|
|
|
STATEDIFF_OPTS=""
|
|
if [ "$CERC_RUN_STATEDIFF" == "true" ]; then
|
|
ready=0
|
|
while [ $ready -eq 0 ]; do
|
|
echo "Waiting for statediff DB..."
|
|
sleep 1
|
|
export PGPASSWORD="$CERC_STATEDIFF_DB_PASSWORD"
|
|
result=$(psql -h "$CERC_STATEDIFF_DB_HOST" \
|
|
-p "$CERC_STATEDIFF_DB_PORT" \
|
|
-U "$CERC_STATEDIFF_DB_USER" \
|
|
-d "$CERC_STATEDIFF_DB_NAME" \
|
|
-t -c 'select max(version_id) from goose_db_version;' 2>/dev/null | awk '{ print $1 }')
|
|
if [ -n "$result" ] && [ $result -ge $CERC_STATEDIFF_DB_GOOSE_MIN_VER ]; then
|
|
echo "DB ready..."
|
|
ready=1
|
|
fi
|
|
done
|
|
STATEDIFF_OPTS="--statediff=true \
|
|
--statediff.db.host=$CERC_STATEDIFF_DB_HOST \
|
|
--statediff.db.name=$CERC_STATEDIFF_DB_NAME \
|
|
--statediff.db.nodeid=$CERC_STATEDIFF_DB_NODE_ID \
|
|
--statediff.db.password=$CERC_STATEDIFF_DB_PASSWORD \
|
|
--statediff.db.port=$CERC_STATEDIFF_DB_PORT \
|
|
--statediff.db.user=$CERC_STATEDIFF_DB_USER \
|
|
--statediff.db.logstatements=${CERC_STATEDIFF_DB_LOG_STATEMENTS:-false} \
|
|
--statediff.db.copyfrom=${CERC_STATEDIFF_DB_COPY_FROM:-true} \
|
|
--statediff.waitforsync=true \
|
|
--statediff.writing=true"
|
|
fi
|
|
|
|
$START_CMD \
|
|
--datadir=~/ethdata \
|
|
--bootnodes="${ENODE}" \
|
|
--allow-insecure-unlock \
|
|
--http \
|
|
--http.addr="0.0.0.0" \
|
|
--http.vhosts="*" \
|
|
--http.api="${CERC_GETH_HTTP_APIS:-eth,web3,net,admin,personal,debug,statediff}" \
|
|
--http.corsdomain="*" \
|
|
--authrpc.addr="0.0.0.0" \
|
|
--authrpc.vhosts="*" \
|
|
--authrpc.jwtsecret="/opt/testnet/build/el/jwtsecret" \
|
|
--ws \
|
|
--ws.addr="0.0.0.0" \
|
|
--ws.origins="*" \
|
|
--ws.api="${CERC_GETH_WS_APIS:-eth,web3,net,admin,personal,debug,statediff}" \
|
|
--http.corsdomain="*" \
|
|
--networkid="${NETWORK_ID}" \
|
|
--netrestrict="${NETRESTRICT}" \
|
|
--gcmode archive \
|
|
--txlookuplimit=0 \
|
|
--cache.preimages \
|
|
--syncmode=full \
|
|
--mine \
|
|
--miner.threads=1 \
|
|
--metrics \
|
|
--metrics.addr="0.0.0.0" \
|
|
--verbosity=${CERC_GETH_VERBOSITY:-3} \
|
|
--vmodule="${CERC_GETH_VMODULE:-statediff/*=5}" \
|
|
--miner.etherbase="${ETHERBASE}" ${STATEDIFF_OPTS} \
|
|
&
|
|
|
|
geth_pid=$!
|
|
fi
|
|
|
|
wait $geth_pid
|