solana/ci/testnet-deploy.sh

252 lines
5.3 KiB
Bash
Raw Normal View History

#!/usr/bin/env bash
set -e
2018-08-27 20:37:35 -07:00
cd "$(dirname "$0")"/..
2018-12-22 12:34:30 -08:00
source ci/upload-ci-artifact.sh
2018-07-16 12:05:48 -07:00
zone=
bootstrapFullNodeAddress=
bootstrapFullNodeMachineType=
clientNodeCount=0
additionalFullNodeCount=10
publicNetwork=false
2019-01-08 14:28:46 -08:00
skipSetup=false
skipStart=false
externalNode=false
2018-11-07 13:32:48 -08:00
tarChannelOrTag=edge
delete=false
2018-09-26 10:27:31 -07:00
enableGpu=false
bootDiskType=""
2018-12-05 17:33:32 -08:00
leaderRotation=true
blockstreamer=false
2018-08-27 20:37:35 -07:00
usage() {
exitcode=0
if [[ -n "$1" ]]; then
exitcode=1
echo "Error: $*"
fi
cat <<EOF
2018-11-06 19:23:20 -08:00
usage: $0 [name] [cloud] [zone] [options...]
Deploys a CD testnet
name - name of the network
2018-11-06 19:23:20 -08:00
cloud - cloud provider to use (gce, ec2)
zone - cloud provider zone to deploy the network into
options:
2018-11-07 10:33:20 -08:00
-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)
2018-11-07 13:32:48 -08:00
(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=4,type=nvidia-tesla-k80)
2018-09-26 10:27:31 -07:00
-g - Enable GPU (default: $enableGpu)
2018-12-05 17:33:32 -08:00
-b - Disable leader rotation
-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
2019-01-08 14:28:46 -08:00
-r - Reuse existing node/ledger configuration from a
2019-02-16 10:01:27 -08:00
previous |start| (ie, don't run ./multinode-demo/setup.sh).
2019-01-08 14:28:46 -08:00
Note: the SOLANA_METRICS_CONFIG environment variable is used to configure
metrics
EOF
exit $exitcode
}
netName=$1
2018-11-06 19:23:20 -08:00
cloudProvider=$2
zone=$3
[[ -n $netName ]] || usage
2018-11-06 19:23:20 -08:00
[[ -n $cloudProvider ]] || usage "Cloud provider not specified"
[[ -n $zone ]] || usage "Zone not specified"
2018-11-06 19:23:20 -08:00
shift 3
2018-07-12 19:47:07 -07:00
while getopts "h?p:Pn:c:t:gG:a:Dbd:rusx" opt; do
case $opt in
h | \?)
usage
2018-07-20 08:50:08 -07:00
;;
P)
publicNetwork=true
;;
2018-09-07 08:05:52 -07:00
n)
additionalFullNodeCount=$OPTARG
2018-09-07 08:05:52 -07:00
;;
c)
clientNodeCount=$OPTARG
;;
t)
case $OPTARG in
2018-11-07 10:33:20 -08:00
edge|beta|stable|v*)
2018-11-07 13:32:48 -08:00
tarChannelOrTag=$OPTARG
;;
*)
usage "Invalid release channel: $OPTARG"
;;
esac
;;
2018-12-05 17:33:32 -08:00
b)
leaderRotation=false
;;
2018-09-26 10:27:31 -07:00
g)
enableGpu=true
;;
G)
enableGpu=true
bootstrapFullNodeMachineType=$OPTARG
;;
a)
bootstrapFullNodeAddress=$OPTARG
;;
d)
bootDiskType=$OPTARG
;;
D)
delete=true
2018-07-20 08:50:08 -07:00
;;
2019-01-08 14:28:46 -08:00
r)
skipSetup=true
;;
s)
skipStart=true
;;
x)
externalNode=true
;;
2019-02-17 10:45:21 -08:00
u)
blockstreamer=true
2019-02-17 10:45:21 -08:00
;;
2018-07-20 08:50:08 -07:00
*)
usage "Error: unhandled option: $opt"
2018-07-20 08:50:08 -07:00
;;
esac
done
shutdown() {
exitcode=$?
set +e
2018-12-23 09:11:15 -08:00
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
}
2018-12-23 09:11:15 -08:00
rm -rf net/{log,-deploy}
trap shutdown EXIT INT
set -x
2019-01-08 14:28:46 -08:00
if ! $skipSetup; then
echo "--- $cloudProvider.sh delete"
time net/"$cloudProvider".sh delete -z "$zone" -p "$netName" ${externalNode:+-x}
2019-01-08 14:28:46 -08:00
if $delete; then
exit 0
fi
2019-01-08 14:28:46 -08:00
echo "--- $cloudProvider.sh create"
create_args=(
-p "$netName"
-z "$zone"
-a "$bootstrapFullNodeAddress"
-c "$clientNodeCount"
-n "$additionalFullNodeCount"
)
if $blockstreamer; then
2019-02-17 10:45:21 -08:00
create_args+=(-u)
fi
if [[ -n $bootDiskType ]]; then
create_args+=(-d "$bootDiskType")
fi
2019-01-08 14:28:46 -08:00
if $enableGpu; then
if [[ -z $bootstrapFullNodeMachineType ]]; then
create_args+=(-g)
else
create_args+=(-G "$bootstrapFullNodeMachineType")
fi
fi
if ! $leaderRotation; then
create_args+=(-b)
fi
if $publicNetwork; then
create_args+=(-P)
fi
if $externalNode; then
create_args+=(-x)
fi
2019-01-08 14:28:46 -08:00
time net/"$cloudProvider".sh create "${create_args[@]}"
else
echo "--- $cloudProvider.sh config"
config_args=(
-p "$netName"
-z "$zone"
)
if $publicNetwork; then
config_args+=(-P)
fi
time net/"$cloudProvider".sh config "${config_args[@]}"
fi
net/init-metrics.sh -e
2018-09-06 20:38:11 -07:00
echo "+++ $cloudProvider.sh info"
net/"$cloudProvider".sh info
2018-09-06 21:07:11 -07:00
echo --- net.sh start
maybeRejectExtraNodes=
if ! $publicNetwork; then
maybeRejectExtraNodes="-o rejectExtraNodes"
fi
maybeNoValidatorSanity=
if [[ -n $NO_VALIDATOR_SANITY ]]; then
maybeNoValidatorSanity="-o noValidatorSanity"
fi
maybeNoLedgerVerify=
if [[ -n $NO_LEDGER_VERIFY ]]; then
maybeNoLedgerVerify="-o noLedgerVerify"
fi
2018-12-23 09:11:15 -08:00
2019-01-08 14:28:46 -08:00
maybeSkipSetup=
if $skipSetup; then
maybeSkipSetup="-r"
fi
2018-12-23 09:11:15 -08:00
ok=true
if ! $skipStart; then
(
if $skipSetup; then
# TODO: Enable rolling updates
#op=update
op=restart
else
op=start
fi
2019-01-08 14:28:46 -08:00
# shellcheck disable=SC2086 # Don't want to double quote maybeRejectExtraNodes
time net/net.sh $op -t "$tarChannelOrTag" \
$maybeSkipSetup $maybeRejectExtraNodes $maybeNoValidatorSanity $maybeNoLedgerVerify
) || ok=false
net/net.sh logs
fi
2018-12-23 09:11:15 -08:00
$ok