405 lines
9.8 KiB
Bash
Executable File
405 lines
9.8 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
set -e
|
|
|
|
cd "$(dirname "$0")"/..
|
|
source ci/upload-ci-artifact.sh
|
|
|
|
zone=
|
|
bootstrapFullNodeAddress=
|
|
bootstrapFullNodeMachineType=
|
|
clientNodeCount=0
|
|
additionalFullNodeCount=10
|
|
publicNetwork=false
|
|
stopNetwork=false
|
|
reuseLedger=false
|
|
skipCreate=false
|
|
skipStart=false
|
|
externalNode=false
|
|
failOnValidatorBootupFailure=true
|
|
tarChannelOrTag=edge
|
|
delete=false
|
|
enableGpu=false
|
|
bootDiskType=""
|
|
blockstreamer=false
|
|
fetchLogs=true
|
|
maybeHashesPerTick=
|
|
maybeDisableAirdrops=
|
|
maybeInternalNodesStakeLamports=
|
|
maybeInternalNodesLamports=
|
|
maybeExternalPrimordialAccountsFile=
|
|
maybeLamports=
|
|
maybeLetsEncrypt=
|
|
maybeFullnodeAdditionalDiskSize=
|
|
maybeNoSnapshot=
|
|
maybeLimitLedgerSize=
|
|
|
|
usage() {
|
|
exitcode=0
|
|
if [[ -n "$1" ]]; then
|
|
exitcode=1
|
|
echo "Error: $*"
|
|
fi
|
|
cat <<EOF
|
|
usage: $0 -p network-name -C cloud -z zone1 [-z zone2] ... [-z zoneN] [options...]
|
|
|
|
Deploys a CD testnet
|
|
|
|
mandatory arguments:
|
|
-p [network-name] - name of the network
|
|
-C [cloud] - cloud provider to use (gce, ec2)
|
|
-z [zone] - cloud provider zone to deploy the network into. Must specify at least one zone
|
|
|
|
options:
|
|
-t edge|beta|stable|vX.Y.Z - Deploy the latest tarball release for the
|
|
specified release channel (edge|beta|stable) or release tag
|
|
(vX.Y.Z)
|
|
(default: $tarChannelOrTag)
|
|
-n [number] - Number of additional full nodes (default: $additionalFullNodeCount)
|
|
-c [number] - Number of client bencher nodes (default: $clientNodeCount)
|
|
-u - Include a Blockstreamer (default: $blockstreamer)
|
|
-P - Use public network IP addresses (default: $publicNetwork)
|
|
-G - Enable GPU, and set count/type of GPUs to use (e.g n1-standard-16 --accelerator count=2,type=nvidia-tesla-v100)
|
|
-g - Enable GPU (default: $enableGpu)
|
|
-a [address] - Set the bootstrap fullnode's external IP address to this GCE address
|
|
-d [disk-type] - Specify a boot disk type (default None) Use pd-ssd to get ssd on GCE.
|
|
-D - Delete the network
|
|
-r - Reuse existing node/ledger configuration from a
|
|
previous |start| (ie, don't run ./multinode-demo/setup.sh).
|
|
-x - External node. Default: false
|
|
-e - Skip create. Assume the nodes have already been created
|
|
-s - Skip start. Nodes will still be created or configured, but network software will not be started.
|
|
-S - Stop network software without tearing down nodes.
|
|
-f - Discard validator nodes that didn't bootup successfully
|
|
--no-airdrop
|
|
- If set, disables airdrops. Nodes must be funded in genesis block when airdrops are disabled.
|
|
--internal-nodes-stake-lamports NUM_LAMPORTS
|
|
- Amount to stake internal nodes.
|
|
--internal-nodes-lamports NUM_LAMPORTS
|
|
- Amount to fund internal nodes in genesis block
|
|
--external-accounts-file FILE_PATH
|
|
- Path to external Primordial Accounts file, if it exists.
|
|
--hashes-per-tick NUM_HASHES|sleep|auto
|
|
- Override the default --hashes-per-tick for the cluster
|
|
--lamports NUM_LAMPORTS
|
|
- Specify the number of lamports to mint (default 100000000000000)
|
|
--skip-deploy-update
|
|
- If set, will skip software update deployment
|
|
--skip-remote-log-retrieval
|
|
- If set, will not fetch logs from remote nodes
|
|
--letsencrypt [dns name]
|
|
- Attempt to generate a TLS certificate using this DNS name
|
|
--fullnode-additional-disk-size-gb [number]
|
|
- Size of additional disk in GB for all fullnodes
|
|
--no-snapshot-fetch
|
|
- If set, disables booting validators from a snapshot
|
|
|
|
Note: the SOLANA_METRICS_CONFIG environment variable is used to configure
|
|
metrics
|
|
EOF
|
|
exit $exitcode
|
|
}
|
|
|
|
zone=()
|
|
|
|
shortArgs=()
|
|
while [[ -n $1 ]]; do
|
|
if [[ ${1:0:2} = -- ]]; then
|
|
if [[ $1 = --hashes-per-tick ]]; then
|
|
maybeHashesPerTick="$1 $2"
|
|
shift 2
|
|
elif [[ $1 = --lamports ]]; then
|
|
maybeLamports="$1 $2"
|
|
shift 2
|
|
elif [[ $1 = --no-airdrop ]]; then
|
|
maybeDisableAirdrops=$1
|
|
shift 1
|
|
elif [[ $1 = --internal-nodes-stake-lamports ]]; then
|
|
maybeInternalNodesStakeLamports="$1 $2"
|
|
shift 2
|
|
elif [[ $1 = --internal-nodes-lamports ]]; then
|
|
maybeInternalNodesLamports="$1 $2"
|
|
shift 2
|
|
elif [[ $1 = --external-accounts-file ]]; then
|
|
maybeExternalPrimordialAccountsFile="$1 $2"
|
|
shift 2
|
|
elif [[ $1 = --skip-remote-log-retrieval ]]; then
|
|
fetchLogs=false
|
|
shift 1
|
|
elif [[ $1 = --letsencrypt ]]; then
|
|
maybeLetsEncrypt="$1 $2"
|
|
shift 2
|
|
elif [[ $1 = --fullnode-additional-disk-size-gb ]]; then
|
|
maybeFullnodeAdditionalDiskSize="$1 $2"
|
|
shift 2
|
|
elif [[ $1 == --machine-type* ]]; then # Bypass quoted long args for GPUs
|
|
shortArgs+=("$1")
|
|
shift
|
|
elif [[ $1 = --no-snapshot-fetch ]]; then
|
|
maybeNoSnapshot=$1
|
|
shift 1
|
|
elif [[ $1 = --limit-ledger-size ]]; then
|
|
maybeLimitLedgerSize=$1
|
|
shift 1
|
|
else
|
|
usage "Unknown long option: $1"
|
|
fi
|
|
else
|
|
shortArgs+=("$1")
|
|
shift
|
|
fi
|
|
done
|
|
|
|
while getopts "h?p:Pn:c:t:gG:a:Dd:rusxz:p:C:Sfe" opt "${shortArgs[@]}"; do
|
|
case $opt in
|
|
h | \?)
|
|
usage
|
|
;;
|
|
p)
|
|
netName=$OPTARG
|
|
;;
|
|
C)
|
|
cloudProvider=$OPTARG
|
|
;;
|
|
z)
|
|
zone+=("$OPTARG")
|
|
;;
|
|
P)
|
|
publicNetwork=true
|
|
;;
|
|
n)
|
|
additionalFullNodeCount=$OPTARG
|
|
;;
|
|
c)
|
|
clientNodeCount=$OPTARG
|
|
;;
|
|
t)
|
|
case $OPTARG in
|
|
edge|beta|stable|v*)
|
|
tarChannelOrTag=$OPTARG
|
|
;;
|
|
*)
|
|
usage "Invalid release channel: $OPTARG"
|
|
;;
|
|
esac
|
|
;;
|
|
g)
|
|
enableGpu=true
|
|
;;
|
|
G)
|
|
enableGpu=true
|
|
bootstrapFullNodeMachineType=$OPTARG
|
|
;;
|
|
a)
|
|
bootstrapFullNodeAddress=$OPTARG
|
|
;;
|
|
d)
|
|
bootDiskType=$OPTARG
|
|
;;
|
|
D)
|
|
delete=true
|
|
;;
|
|
r)
|
|
reuseLedger=true
|
|
;;
|
|
e)
|
|
skipCreate=true
|
|
;;
|
|
s)
|
|
skipStart=true
|
|
;;
|
|
x)
|
|
externalNode=true
|
|
;;
|
|
f)
|
|
failOnValidatorBootupFailure=false
|
|
;;
|
|
u)
|
|
blockstreamer=true
|
|
;;
|
|
S)
|
|
stopNetwork=true
|
|
;;
|
|
*)
|
|
usage "Unknown option: $opt"
|
|
;;
|
|
esac
|
|
done
|
|
|
|
[[ -n $netName ]] || usage
|
|
[[ -n $cloudProvider ]] || usage "Cloud provider not specified"
|
|
[[ -n ${zone[*]} ]] || usage "At least one zone must be specified"
|
|
|
|
shutdown() {
|
|
exitcode=$?
|
|
|
|
set +e
|
|
if [[ -d net/log ]]; then
|
|
mv net/log net/log-deploy
|
|
for logfile in net/log-deploy/*; do
|
|
if [[ -f $logfile ]]; then
|
|
upload-ci-artifact "$logfile"
|
|
tail "$logfile"
|
|
fi
|
|
done
|
|
fi
|
|
exit $exitcode
|
|
}
|
|
rm -rf net/{log,-deploy}
|
|
trap shutdown EXIT INT
|
|
|
|
set -x
|
|
|
|
# Build a string to pass zone opts to $cloudProvider.sh: "-z zone1 -z zone2 ..."
|
|
zone_args=()
|
|
for val in "${zone[@]}"; do
|
|
zone_args+=("-z $val")
|
|
done
|
|
|
|
if $stopNetwork; then
|
|
skipCreate=true
|
|
fi
|
|
|
|
if $delete; then
|
|
skipCreate=false
|
|
fi
|
|
|
|
# Create the network
|
|
if ! $skipCreate; then
|
|
echo "--- $cloudProvider.sh delete"
|
|
# shellcheck disable=SC2068
|
|
time net/"$cloudProvider".sh delete ${zone_args[@]} -p "$netName" ${externalNode:+-x}
|
|
if $delete; then
|
|
exit 0
|
|
fi
|
|
|
|
echo "--- $cloudProvider.sh create"
|
|
create_args=(
|
|
-p "$netName"
|
|
-a "$bootstrapFullNodeAddress"
|
|
-c "$clientNodeCount"
|
|
-n "$additionalFullNodeCount"
|
|
)
|
|
# shellcheck disable=SC2206
|
|
create_args+=(${zone_args[@]})
|
|
|
|
if [[ -n $maybeLetsEncrypt ]]; then
|
|
# shellcheck disable=SC2206 # Do not want to quote $maybeLetsEncrypt
|
|
create_args+=($maybeLetsEncrypt)
|
|
fi
|
|
|
|
if $blockstreamer; then
|
|
create_args+=(-u)
|
|
fi
|
|
|
|
if [[ -n $bootDiskType ]]; then
|
|
create_args+=(-d "$bootDiskType")
|
|
fi
|
|
|
|
if $enableGpu; then
|
|
if [[ -z $bootstrapFullNodeMachineType ]]; then
|
|
create_args+=(-g)
|
|
else
|
|
create_args+=(-G "$bootstrapFullNodeMachineType")
|
|
fi
|
|
fi
|
|
|
|
if $publicNetwork; then
|
|
create_args+=(-P)
|
|
fi
|
|
|
|
if $externalNode; then
|
|
create_args+=(-x)
|
|
fi
|
|
|
|
if ! $failOnValidatorBootupFailure; then
|
|
create_args+=(-f)
|
|
fi
|
|
|
|
if [[ -n $maybeFullnodeAdditionalDiskSize ]]; then
|
|
# shellcheck disable=SC2206 # Do not want to quote
|
|
create_args+=($maybeFullnodeAdditionalDiskSize)
|
|
fi
|
|
|
|
time net/"$cloudProvider".sh create "${create_args[@]}"
|
|
else
|
|
echo "--- $cloudProvider.sh config"
|
|
config_args=(
|
|
-p "$netName"
|
|
)
|
|
# shellcheck disable=SC2206
|
|
config_args+=(${zone_args[@]})
|
|
if $publicNetwork; then
|
|
config_args+=(-P)
|
|
fi
|
|
|
|
if $externalNode; then
|
|
config_args+=(-x)
|
|
fi
|
|
|
|
if ! $failOnValidatorBootupFailure; then
|
|
config_args+=(-f)
|
|
fi
|
|
|
|
time net/"$cloudProvider".sh config "${config_args[@]}"
|
|
fi
|
|
net/init-metrics.sh -e
|
|
|
|
echo "+++ $cloudProvider.sh info"
|
|
net/"$cloudProvider".sh info
|
|
|
|
if $stopNetwork; then
|
|
echo --- net.sh stop
|
|
time net/net.sh stop
|
|
exit 0
|
|
fi
|
|
|
|
ok=true
|
|
if ! $skipStart; then
|
|
(
|
|
if $skipCreate; then
|
|
op=restart
|
|
else
|
|
op=start
|
|
fi
|
|
echo "--- net.sh $op"
|
|
args=("$op" -t "$tarChannelOrTag")
|
|
|
|
if ! $publicNetwork; then
|
|
args+=(-o rejectExtraNodes)
|
|
fi
|
|
if [[ -n $NO_VALIDATOR_SANITY ]]; then
|
|
args+=(-o noValidatorSanity)
|
|
fi
|
|
if [[ -n $NO_INSTALL_CHECK ]]; then
|
|
args+=(-o noInstallCheck)
|
|
fi
|
|
if $reuseLedger; then
|
|
args+=(-r)
|
|
fi
|
|
|
|
if ! $failOnValidatorBootupFailure; then
|
|
args+=(-F)
|
|
fi
|
|
|
|
# shellcheck disable=SC2206 # Do not want to quote
|
|
args+=(
|
|
$maybeHashesPerTick
|
|
$maybeDisableAirdrops
|
|
$maybeInternalNodesStakeLamports
|
|
$maybeInternalNodesLamports
|
|
$maybeExternalPrimordialAccountsFile
|
|
$maybeLamports
|
|
$maybeNoSnapshot
|
|
$maybeLimitLedgerSize
|
|
)
|
|
|
|
time net/net.sh "${args[@]}"
|
|
) || ok=false
|
|
|
|
if $fetchLogs; then
|
|
net/net.sh logs
|
|
fi
|
|
fi
|
|
|
|
$ok
|