From 36281975c87210274ac6d53eb4674d42d04b2e5f Mon Sep 17 00:00:00 2001 From: Peter Zhang Date: Sun, 21 Apr 2024 20:06:41 +0800 Subject: [PATCH] add deploy scripts --- networks/testnet/deploy.sh | 78 +++++++++++++ networks/testnet/init-genesis.sh | 194 +++++++++++++++++++++++++++++++ networks/testnet/install.sh | 20 ++++ 3 files changed, 292 insertions(+) create mode 100755 networks/testnet/deploy.sh create mode 100755 networks/testnet/init-genesis.sh create mode 100755 networks/testnet/install.sh diff --git a/networks/testnet/deploy.sh b/networks/testnet/deploy.sh new file mode 100755 index 00000000..5e9ba33c --- /dev/null +++ b/networks/testnet/deploy.sh @@ -0,0 +1,78 @@ +#!/bin/bash + +function help() { + echo "Usage: deploy.sh IP1,IP2,IP3 [options]" + echo "" + echo " -i Identity file" + echo " -k Keyring password to create key (for Linux only)" + echo " -n Network (default: testnet)" + echo " -c Chain ID (default: \"zgtendermint_9000-1\")" + echo "" +} + +if [[ $# -eq 0 ]]; then + help + exit 1 +fi + +set -e + +IP_LIST=$1 +shift +PEM_FLAG="" +KEYRING_PASSWORD="" +NETWORK="testnet" +INIT_GENESIS_ENV="" + +while [[ $# -gt 0 ]]; do + case $1 in + -i) + PEM_FLAG="-i $2"; + shift; shift + ;; + -k) + KEYRING_PASSWORD=$2; + shift; shift + ;; + -n) + NETWORK=$2 + INIT_GENESIS_ENV="$INIT_GENESIS_ENV export ROOT_DIR=$2;" + shift; shift + ;; + -c) + INIT_GENESIS_ENV="$INIT_GENESIS_ENV export CHAIN_ID=$2;" + shift; shift + ;; + *) + help + echo "Unknown flag passed: \"$1\"" + exit 1 + ;; + esac +done + +IFS=","; declare -a IPS=($IP_LIST); unset IFS +NUM_NODES=${#IPS[@]} + +# Install dependent libraries and binary +for ((i=0; i<$NUM_NODES; i++)) do + ssh $PEM_FLAG ubuntu@${IPS[$i]} "git clone https://github.com/0glabs/0g-chain.git; cd 0g-chain; ./networks/testnet/install.sh" +done + +# Create genesis config on node0 +ssh $PEM_FLAG ubuntu@${IPS[0]} "cd 0g-chain/networks/testnet; $INIT_GENESIS_ENV ./init-genesis.sh $IP_LIST $KEYRING_PASSWORD; tar czf ~/$NETWORK.tar.gz $NETWORK; rm -rf $NETWORK" +scp $PEM_FLAG ubuntu@${IPS[0]}:$NETWORK.tar.gz . +ssh $PEM_FLAG ubuntu@${IPS[0]} "rm $NETWORK.tar.gz" + +# Copy genesis config to remote nodes +tar xzf $NETWORK.tar.gz +rm $NETWORK.tar.gz +cd $NETWORK +for ((i=0; i<$NUM_NODES; i++)) do + tar czf node$i.tar.gz node$i + scp $PEM_FLAG node$i.tar.gz ubuntu@${IPS[$i]}:~ + ssh $PEM_FLAG ubuntu@${IPS[$i]} "rm -rf kava-prod; tar xzf node$i.tar.gz; rm node$i.tar.gz; mv node$i kava-prod" + rm node$i.tar.gz +done + +echo -e "\n\nSucceeded to deploy on $NUM_NODES nodes!\n" \ No newline at end of file diff --git a/networks/testnet/init-genesis.sh b/networks/testnet/init-genesis.sh new file mode 100755 index 00000000..5ac932a7 --- /dev/null +++ b/networks/testnet/init-genesis.sh @@ -0,0 +1,194 @@ +#!/bin/bash + +ROOT_DIR=${ROOT_DIR:-testnet} +CHAIN_ID=${CHAIN_ID:-zgtendermint_9000-1} + +# Usage: init-genesis.sh IP1,IP2,IP3 KEYRING_PASSWORD +OS_NAME=`uname -o` +USAGE="Usage: ${BASH_SOURCE[0]} IP1,IP2,IP3" +if [[ "$OS_NAME" = "GNU/Linux" ]]; then + USAGE="$USAGE KEYRING_PASSWORD" +fi + +if [[ $# -eq 0 ]]; then + echo "IP list not specified" + echo $USAGE + exit 1 +fi + +if [[ "$OS_NAME" = "GNU/Linux" ]]; then + if [[ $# -eq 1 ]]; then + echo "Keyring password not specified" + echo $USAGE + exit 1 + fi + + PASSWORD=$2 +fi + +kava version 2>/dev/null || export PATH=$PATH:$(go env GOPATH)/bin + +set -e + +IFS=","; declare -a IPS=($1); unset IFS + +NUM_NODES=${#IPS[@]} +BALANCE=$((100000000/$NUM_NODES))kava +STAKING=$((50000000/$NUM_NODES))kava + +# Init configs +for ((i=0; i<$NUM_NODES; i++)) do + HOMEDIR="$ROOT_DIR"/node$i + + # Change parameter token denominations to neuron + GENESIS="$HOMEDIR"/config/genesis.json + TMP_GENESIS="$HOMEDIR"/config/tmp_genesis.json + + # Init + kava init "node$i" --home "$HOMEDIR" --chain-id "$CHAIN_ID" >/dev/null 2>&1 + + # Replace stake with ukava + sed -in-place='' 's/stake/ukava/g' "$GENESIS" + + # Replace the default evm denom of aphoton with ukava + sed -in-place='' 's/aphoton/akava/g' "$GENESIS" + + cat $GENESIS | jq '.consensus_params.block.max_gas = "25000000"' >$TMP_GENESIS && mv $TMP_GENESIS $GENESIS + + # Zero out the total supply so it gets recalculated during InitGenesis + cat $GENESIS | jq '.app_state.bank.supply = []' >$TMP_GENESIS && mv $TMP_GENESIS $GENESIS + + # Disable fee market + cat $GENESIS | jq '.app_state.feemarket.params.no_base_fee = true' >$TMP_GENESIS && mv $TMP_GENESIS $GENESIS + + # Disable london fork + cat $GENESIS | jq '.app_state.evm.params.chain_config.london_block = null' >$TMP_GENESIS && mv $TMP_GENESIS $GENESIS + cat $GENESIS | jq '.app_state.evm.params.chain_config.arrow_glacier_block = null' >$TMP_GENESIS && mv $TMP_GENESIS $GENESIS + cat $GENESIS | jq '.app_state.evm.params.chain_config.gray_glacier_block = null' >$TMP_GENESIS && mv $TMP_GENESIS $GENESIS + cat $GENESIS | jq '.app_state.evm.params.chain_config.merge_netsplit_block = null' >$TMP_GENESIS && mv $TMP_GENESIS $GENESIS + cat $GENESIS | jq '.app_state.evm.params.chain_config.shanghai_block = null' >$TMP_GENESIS && mv $TMP_GENESIS $GENESIS + cat $GENESIS | jq '.app_state.evm.params.chain_config.cancun_block = null' >$TMP_GENESIS && mv $TMP_GENESIS $GENESIS + + # Add earn vault + cat $GENESIS | jq '.app_state.earn.params.allowed_vaults = [ + { + denom: "usdx", + strategies: ["STRATEGY_TYPE_HARD"], + }, + { + denom: "bkava", + strategies: ["STRATEGY_TYPE_SAVINGS"], + }]' >$TMP_GENESIS && mv $TMP_GENESIS $GENESIS + + cat $GENESIS | jq '.app_state.savings.params.supported_denoms = ["bkava-kavavaloper1ffv7nhd3z6sych2qpqkk03ec6hzkmufyz4scd0"]' >$TMP_GENESIS && mv $TMP_GENESIS $GENESIS + + # cat "$GENESIS" | jq '.app_state["staking"]["params"]["bond_denom"]="ukava"' >"$TMP_GENESIS" && mv "$TMP_GENESIS" "$GENESIS" + # cat "$GENESIS" | jq '.app_state["gov"]["params"]["min_deposit"][0]["denom"]="neuron"' >"$TMP_GENESIS" && mv "$TMP_GENESIS" "$GENESIS" + + # Change app.toml + APP_TOML="$HOMEDIR"/config/app.toml + sed -i 's/minimum-gas-prices = "0akava"/minimum-gas-prices = "1000000000ukava"/' "$APP_TOML" + sed -i '/\[json-rpc\]/,/^\[/ s/enable = false/enable = true/' "$APP_TOML" + sed -i '/\[json-rpc\]/,/^\[/ s/address = "127.0.0.1:8545"/address = "0.0.0.0:8545"/' "$APP_TOML" + + # Set evm tracer to json + sed -in-place='' 's/tracer = ""/tracer = "json"/g' "$APP_TOML" + + # Enable full error trace to be returned on tx failure + sed -in-place='' '/iavl-cache-size/a\ +trace = true' "$APP_TOML" +done + +# Update seeds in config.toml +SEEDS="" +for ((i=0; i<$NUM_NODES; i++)) do + if [[ $i -gt 0 ]]; then SEEDS=$SEEDS,; fi + NODE_ID=`kava tendermint show-node-id --home $ROOT_DIR/node$i` + SEEDS=$SEEDS$NODE_ID@${IPS[$i]}:26656 +done + +for ((i=0; i<$NUM_NODES; i++)) do + sed -i "/seeds = /c\seeds = \"$SEEDS\"" "$ROOT_DIR"/node$i/config/config.toml +done + +# Prepare validators +# +# Note, keyring backend `file` works bad on Windows, and `add-genesis-account` +# do not supports --keyring-dir flag. As a result, we use keyring backend `os`, +# which is the default value. +# +# Where key stored: +# - Windows: Windows credentials management. +# - Linux: under `--home` specified folder. +if [[ "$OS_NAME" = "Msys" ]]; then + for ((i=0; i<$NUM_NODES; i++)) do + VALIDATOR="0gchain_9000_validator_$i" + set +e + ret=`kava keys list --keyring-backend os -n | grep $VALIDATOR` + set -e + if [[ "$ret" = "" ]]; then + echo "Create validator key: $VALIDATOR" + kava keys add $VALIDATOR --keyring-backend os + fi + done +elif [[ "$OS_NAME" = "GNU/Linux" ]]; then + # Create N validators for node0 + for ((i=0; i<$NUM_NODES; i++)) do + yes $PASSWORD | kava keys add "0gchain_9000_validator_$i" --keyring-backend os --home "$ROOT_DIR"/node0 + done + + # Copy validators to other nodes + for ((i=1; i<$NUM_NODES; i++)) do + cp "$ROOT_DIR"/node0/keyhash "$ROOT_DIR"/node$i + cp "$ROOT_DIR"/node0/*.address "$ROOT_DIR"/node$i + cp "$ROOT_DIR"/node0/*.info "$ROOT_DIR"/node$i + done +else + echo -e "\n\nOS: $OS_NAME" + echo "Unsupported OS to generate keys for validators!!!" + exit 1 +fi + +# Add all validators in genesis +for ((i=0; i<$NUM_NODES; i++)) do + for ((j=0; j<$NUM_NODES; j++)) do + if [[ "$OS_NAME" = "GNU/Linux" ]]; then + yes $PASSWORD | kava add-genesis-account "0gchain_9000_validator_$i" $BALANCE --home "$ROOT_DIR/node$j" + else + kava add-genesis-account "0gchain_9000_validator_$i" $BALANCE --home "$ROOT_DIR/node$j" + fi + done +done + +# Prepare genesis txs +mkdir -p "$ROOT_DIR"/gentxs +for ((i=0; i<$NUM_NODES; i++)) do + if [[ "$OS_NAME" = "GNU/Linux" ]]; then + yes $PASSWORD | kava gentx "0gchain_9000_validator_$i" $STAKING --home "$ROOT_DIR/node$i" --output-document "$ROOT_DIR/gentxs/node$i.json" + else + kava gentx "0gchain_9000_validator_$i" $STAKING --home "$ROOT_DIR/node$i" --output-document "$ROOT_DIR/gentxs/node$i.json" + fi +done + +# Create genesis at node0 and copy to other nodes +kava collect-gentxs --home "$ROOT_DIR/node0" --gentx-dir "$ROOT_DIR/gentxs" >/dev/null 2>&1 +sed -i '/persistent_peers = /c\persistent_peers = ""' "$ROOT_DIR"/node0/config/config.toml +kava validate-genesis --home "$ROOT_DIR/node0" +for ((i=1; i<$NUM_NODES; i++)) do + cp "$ROOT_DIR"/node0/config/genesis.json "$ROOT_DIR"/node$i/config/genesis.json +done + +# For linux, backup keys for all validators +if [[ "$OS_NAME" = "GNU/Linux" ]]; then + mkdir -p "$ROOT_DIR"/keyring-os + + cp "$ROOT_DIR"/node0/keyhash "$ROOT_DIR"/keyring-os + cp "$ROOT_DIR"/node0/*.address "$ROOT_DIR"/keyring-os + cp "$ROOT_DIR"/node0/*.info "$ROOT_DIR"/keyring-os + + for ((i=0; i<$NUM_NODES; i++)) do + rm -f "$ROOT_DIR"/node$i/keyhash "$ROOT_DIR"/node$i/*.address "$ROOT_DIR"/node$i/*.info + done +fi + +echo -e "\n\nSucceeded to init genesis!\n" diff --git a/networks/testnet/install.sh b/networks/testnet/install.sh new file mode 100755 index 00000000..48826d64 --- /dev/null +++ b/networks/testnet/install.sh @@ -0,0 +1,20 @@ +#!/bin/bash + +# Install dependent libraries +go version 2>/dev/null || sudo snap install go --classic +jq --version 2>/dev/null || sudo snap install jq +make --version 2>/dev/null || sudo apt install make -y +gcc --version 2>/dev/null || (sudo apt-get update; sudo apt install gcc -y) + +# Build binary +export PATH=$PATH:$(go env GOPATH)/bin +kava version 2>/dev/null +if [[ $? -ne 0 ]]; then + # Make under root dir + SCRIPT_DIR=`dirname "${BASH_SOURCE[0]}"` + cd $SCRIPT_DIR/../.. + make install + + # Add gopath to path + echo 'export PATH=$PATH:$(go env GOPATH)/bin' >> ~/.profile +fi