| 
									
										
										
										
											2018-11-11 08:19:04 -08:00
										 |  |  | #!/usr/bin/env bash
 | 
					
						
							|  |  |  | set -e | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | here=$(dirname "$0") | 
					
						
							|  |  |  | # shellcheck source=net/common.sh | 
					
						
							|  |  |  | source "$here"/common.sh | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  | cloudProvider=$(basename "$0" .sh) | 
					
						
							| 
									
										
										
										
											2018-09-22 16:43:47 -07:00
										 |  |  | bootDiskType="" | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  | case $cloudProvider in | 
					
						
							|  |  |  | gce) | 
					
						
							|  |  |  |   # shellcheck source=net/scripts/gce-provider.sh | 
					
						
							|  |  |  |   source "$here"/scripts/gce-provider.sh | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-18 09:36:11 -07:00
										 |  |  |   cpuBootstrapLeaderMachineType="--machine-type n1-standard-16" | 
					
						
							| 
									
										
										
										
											2018-12-09 09:42:09 -08:00
										 |  |  |   gpuBootstrapLeaderMachineType="$cpuBootstrapLeaderMachineType --accelerator count=4,type=nvidia-tesla-k80" | 
					
						
							|  |  |  |   bootstrapLeaderMachineType=$cpuBootstrapLeaderMachineType | 
					
						
							| 
									
										
										
										
											2019-03-12 17:42:47 -07:00
										 |  |  |   fullNodeMachineType=$cpuBootstrapLeaderMachineType | 
					
						
							| 
									
										
										
										
											2019-04-18 09:36:11 -07:00
										 |  |  |   clientMachineType="--custom-cpu 16 --custom-memory 20GB" | 
					
						
							|  |  |  |   blockstreamerMachineType="--machine-type n1-standard-8" | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  |   ;; | 
					
						
							|  |  |  | ec2) | 
					
						
							|  |  |  |   # shellcheck source=net/scripts/ec2-provider.sh | 
					
						
							|  |  |  |   source "$here"/scripts/ec2-provider.sh | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-04 22:31:42 +00:00
										 |  |  |   cpuBootstrapLeaderMachineType=m4.2xlarge | 
					
						
							| 
									
										
										
										
											2018-12-09 09:42:09 -08:00
										 |  |  |   gpuBootstrapLeaderMachineType=p2.xlarge | 
					
						
							|  |  |  |   bootstrapLeaderMachineType=$cpuBootstrapLeaderMachineType | 
					
						
							| 
									
										
										
										
											2019-04-01 10:01:50 -07:00
										 |  |  |   fullNodeMachineType=$cpuBootstrapLeaderMachineType | 
					
						
							| 
									
										
										
										
											2018-11-06 19:23:20 -08:00
										 |  |  |   clientMachineType=m4.2xlarge | 
					
						
							| 
									
										
										
										
											2019-02-21 16:35:26 -07:00
										 |  |  |   blockstreamerMachineType=m4.2xlarge | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  |   ;; | 
					
						
							| 
									
										
										
										
											2019-04-23 16:41:45 -06:00
										 |  |  | azure) | 
					
						
							|  |  |  |   # shellcheck source=net/scripts/azure-provider.sh | 
					
						
							|  |  |  |   source "$here"/scripts/azure-provider.sh | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   # TODO: Dial in machine types for Azure | 
					
						
							|  |  |  |   cpuBootstrapLeaderMachineType=Standard_D16s_v3 | 
					
						
							|  |  |  |   gpuBootstrapLeaderMachineType=Standard_NC12 | 
					
						
							|  |  |  |   bootstrapLeaderMachineType=$cpuBootstrapLeaderMachineType | 
					
						
							|  |  |  |   fullNodeMachineType=$cpuBootstrapLeaderMachineType | 
					
						
							|  |  |  |   clientMachineType=Standard_D16s_v3 | 
					
						
							|  |  |  |   blockstreamerMachineType=Standard_D16s_v3 | 
					
						
							|  |  |  |   ;; | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  | *) | 
					
						
							|  |  |  |   echo "Error: Unknown cloud provider: $cloudProvider" | 
					
						
							|  |  |  |   ;; | 
					
						
							|  |  |  | esac | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-07 00:18:05 +09:00
										 |  |  | prefix=testnet-dev-${USER//[^A-Za-z0-9]/} | 
					
						
							| 
									
										
										
										
											2018-12-05 16:40:08 -08:00
										 |  |  | additionalFullNodeCount=5 | 
					
						
							| 
									
										
										
										
											2018-08-29 08:13:35 -07:00
										 |  |  | clientNodeCount=1 | 
					
						
							| 
									
										
										
										
											2019-02-21 16:35:26 -07:00
										 |  |  | blockstreamer=false | 
					
						
							| 
									
										
										
										
											2018-12-05 16:40:08 -08:00
										 |  |  | fullNodeBootDiskSizeInGb=1000 | 
					
						
							| 
									
										
										
										
											2018-09-17 08:25:10 -07:00
										 |  |  | clientBootDiskSizeInGb=75 | 
					
						
							| 
									
										
										
										
											2019-04-01 22:54:41 +00:00
										 |  |  | externalNodes=false | 
					
						
							| 
									
										
										
										
											2019-04-24 16:23:26 -07:00
										 |  |  | failOnValidatorBootupFailure=true | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-04 22:21:58 -07:00
										 |  |  | publicNetwork=false | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  | enableGpu=false | 
					
						
							| 
									
										
										
										
											2019-02-17 09:48:27 -08:00
										 |  |  | customAddress= | 
					
						
							| 
									
										
										
										
											2018-12-05 17:33:32 -08:00
										 |  |  | leaderRotation=true | 
					
						
							| 
									
										
										
										
											2019-03-27 22:19:55 +00:00
										 |  |  | zones=() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | containsZone() { | 
					
						
							|  |  |  |   local e match="$1" | 
					
						
							|  |  |  |   shift | 
					
						
							|  |  |  |   for e; do [[ "$e" == "$match" ]] && return 0; done | 
					
						
							|  |  |  |   return 1 | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | usage() { | 
					
						
							|  |  |  |   exitcode=0 | 
					
						
							|  |  |  |   if [[ -n "$1" ]]; then | 
					
						
							|  |  |  |     exitcode=1 | 
					
						
							|  |  |  |     echo "Error: $*" | 
					
						
							|  |  |  |   fi | 
					
						
							|  |  |  |   cat <<EOF | 
					
						
							|  |  |  | usage: $0 [create|config|delete] [common options] [command-specific options] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  | Manage testnet instances | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |  create - create a new testnet (implies 'config') | 
					
						
							|  |  |  |  config - configure the testnet and write a config file describing it | 
					
						
							|  |  |  |  delete - delete the testnet | 
					
						
							| 
									
										
										
										
											2019-01-16 09:38:29 -08:00
										 |  |  |  info   - display information about the currently configured testnet | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |  common options: | 
					
						
							| 
									
										
										
										
											2018-09-06 10:08:34 -07:00
										 |  |  |    -p [prefix]      - Optional common prefix for instance names to avoid | 
					
						
							|  |  |  |                       collisions (default: $prefix) | 
					
						
							| 
									
										
										
										
											2019-04-09 08:51:59 -07:00
										 |  |  |    -z [zone]        - Zone(s) for the nodes (default: $(cloud_DefaultZone)) | 
					
						
							|  |  |  |                       If specified multiple times, the fullnodes will be evenly | 
					
						
							|  |  |  |                       distributed over all specified zones and | 
					
						
							|  |  |  |                       client/blockstreamer nodes will be created in the first | 
					
						
							|  |  |  |                       zone | 
					
						
							|  |  |  |    -x               - append to the existing configuration instead of creating a | 
					
						
							|  |  |  |                       new configuration | 
					
						
							| 
									
										
										
										
											2019-04-24 16:23:26 -07:00
										 |  |  |    -f               - Discard validator nodes that didn't bootup successfully | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |  create-specific options: | 
					
						
							| 
									
										
										
										
											2018-12-09 09:42:09 -08:00
										 |  |  |    -n [number]      - Number of additional fullnodes (default: $additionalFullNodeCount) | 
					
						
							| 
									
										
										
										
											2018-09-05 09:31:50 -07:00
										 |  |  |    -c [number]      - Number of client nodes (default: $clientNodeCount) | 
					
						
							| 
									
										
										
										
											2019-02-21 16:35:26 -07:00
										 |  |  |    -u               - Include a Blockstreamer (default: $blockstreamer) | 
					
						
							| 
									
										
										
										
											2018-09-04 22:21:58 -07:00
										 |  |  |    -P               - Use public network IP addresses (default: $publicNetwork) | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  |    -g               - Enable GPU (default: $enableGpu) | 
					
						
							| 
									
										
										
										
											2019-02-17 09:48:27 -08:00
										 |  |  |    -G               - Enable GPU, and set count/type of GPUs to use | 
					
						
							| 
									
										
										
										
											2019-04-18 09:36:11 -07:00
										 |  |  |                       (e.g $gpuBootstrapLeaderMachineType) | 
					
						
							| 
									
										
										
										
											2019-02-21 16:35:26 -07:00
										 |  |  |    -a [address]     - Address to be be assigned to the Blockstreamer if present, | 
					
						
							| 
									
										
										
										
											2019-02-17 09:48:27 -08:00
										 |  |  |                       otherwise the bootstrap fullnode. | 
					
						
							|  |  |  |                       * For GCE, [address] is the "name" of the desired External | 
					
						
							|  |  |  |                         IP Address. | 
					
						
							|  |  |  |                       * For EC2, [address] is the "allocation ID" of the desired | 
					
						
							|  |  |  |                         Elastic IP. | 
					
						
							| 
									
										
										
										
											2018-09-22 16:43:47 -07:00
										 |  |  |    -d [disk-type]   - Specify a boot disk type (default None) Use pd-ssd to get ssd on GCE. | 
					
						
							| 
									
										
										
										
											2018-12-05 17:33:32 -08:00
										 |  |  |    -b               - Disable leader rotation | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |  config-specific options: | 
					
						
							| 
									
										
										
										
											2018-12-09 10:03:17 -08:00
										 |  |  |    -P               - Use public network IP addresses (default: $publicNetwork) | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |  delete-specific options: | 
					
						
							| 
									
										
										
										
											2018-09-07 08:57:14 -07:00
										 |  |  |    none | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-16 09:38:29 -08:00
										 |  |  |  info-specific options: | 
					
						
							|  |  |  |    none | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  | EOF | 
					
						
							|  |  |  |   exit $exitcode | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | command=$1 | 
					
						
							|  |  |  | [[ -n $command ]] || usage | 
					
						
							|  |  |  | shift | 
					
						
							| 
									
										
										
										
											2019-01-16 09:38:29 -08:00
										 |  |  | [[ $command = create || $command = config || $command = info || $command = delete ]] || | 
					
						
							|  |  |  |   usage "Invalid command: $command" | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-24 16:23:26 -07:00
										 |  |  | while getopts "h?p:Pn:c:z:gG:a:d:buxf" opt; do | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  |   case $opt in | 
					
						
							|  |  |  |   h | \?) | 
					
						
							|  |  |  |     usage | 
					
						
							|  |  |  |     ;; | 
					
						
							|  |  |  |   p) | 
					
						
							| 
									
										
										
										
											2018-09-06 10:08:34 -07:00
										 |  |  |     [[ ${OPTARG//[^A-Za-z0-9-]/} == "$OPTARG" ]] || usage "Invalid prefix: \"$OPTARG\", alphanumeric only" | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  |     prefix=$OPTARG | 
					
						
							|  |  |  |     ;; | 
					
						
							|  |  |  |   P) | 
					
						
							| 
									
										
										
										
											2018-09-04 22:21:58 -07:00
										 |  |  |     publicNetwork=true | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  |     ;; | 
					
						
							|  |  |  |   n) | 
					
						
							| 
									
										
										
										
											2018-12-05 16:40:08 -08:00
										 |  |  |     additionalFullNodeCount=$OPTARG | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  |     ;; | 
					
						
							|  |  |  |   c) | 
					
						
							|  |  |  |     clientNodeCount=$OPTARG | 
					
						
							|  |  |  |     ;; | 
					
						
							|  |  |  |   z) | 
					
						
							| 
									
										
										
										
											2019-03-27 22:19:55 +00:00
										 |  |  |     containsZone "$OPTARG" "${zones[@]}" || zones+=("$OPTARG") | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  |     ;; | 
					
						
							| 
									
										
										
										
											2018-12-05 17:33:32 -08:00
										 |  |  |   b) | 
					
						
							|  |  |  |     leaderRotation=false | 
					
						
							|  |  |  |     ;; | 
					
						
							| 
									
										
										
										
											2018-09-04 08:17:41 -07:00
										 |  |  |   g) | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  |     enableGpu=true | 
					
						
							| 
									
										
										
										
											2018-12-09 09:42:09 -08:00
										 |  |  |     bootstrapLeaderMachineType=$gpuBootstrapLeaderMachineType | 
					
						
							| 
									
										
										
										
											2019-03-12 17:42:47 -07:00
										 |  |  |     fullNodeMachineType=$bootstrapLeaderMachineType | 
					
						
							| 
									
										
										
										
											2019-04-27 20:45:38 -07:00
										 |  |  |     blockstreamerMachineType=$bootstrapLeaderMachineType | 
					
						
							| 
									
										
										
										
											2018-09-04 08:17:41 -07:00
										 |  |  |     ;; | 
					
						
							| 
									
										
										
										
											2018-09-27 11:55:56 -07:00
										 |  |  |   G) | 
					
						
							|  |  |  |     enableGpu=true | 
					
						
							| 
									
										
										
										
											2018-12-09 09:42:09 -08:00
										 |  |  |     bootstrapLeaderMachineType="$OPTARG" | 
					
						
							| 
									
										
										
										
											2019-03-12 17:42:47 -07:00
										 |  |  |     fullNodeMachineType=$bootstrapLeaderMachineType | 
					
						
							| 
									
										
										
										
											2019-04-27 20:45:38 -07:00
										 |  |  |     blockstreamerMachineType=$bootstrapLeaderMachineType | 
					
						
							| 
									
										
										
										
											2018-09-27 11:55:56 -07:00
										 |  |  |     ;; | 
					
						
							| 
									
										
										
										
											2018-09-05 09:31:50 -07:00
										 |  |  |   a) | 
					
						
							| 
									
										
										
										
											2019-02-17 09:48:27 -08:00
										 |  |  |     customAddress=$OPTARG | 
					
						
							| 
									
										
										
										
											2018-09-05 09:31:50 -07:00
										 |  |  |     ;; | 
					
						
							| 
									
										
										
										
											2018-09-22 16:43:47 -07:00
										 |  |  |   d) | 
					
						
							|  |  |  |     bootDiskType=$OPTARG | 
					
						
							|  |  |  |     ;; | 
					
						
							| 
									
										
										
										
											2019-02-17 09:48:27 -08:00
										 |  |  |   u) | 
					
						
							| 
									
										
										
										
											2019-02-21 16:35:26 -07:00
										 |  |  |     blockstreamer=true | 
					
						
							| 
									
										
										
										
											2019-02-17 09:48:27 -08:00
										 |  |  |     ;; | 
					
						
							| 
									
										
										
										
											2019-04-01 22:54:41 +00:00
										 |  |  |   x) | 
					
						
							|  |  |  |     externalNodes=true | 
					
						
							|  |  |  |     ;; | 
					
						
							| 
									
										
										
										
											2019-04-24 16:23:26 -07:00
										 |  |  |   f) | 
					
						
							|  |  |  |     failOnValidatorBootupFailure=false | 
					
						
							|  |  |  |     ;; | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  |   *) | 
					
						
							| 
									
										
										
										
											2018-11-07 10:03:40 -08:00
										 |  |  |     usage "unhandled option: $opt" | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  |     ;; | 
					
						
							|  |  |  |   esac | 
					
						
							|  |  |  | done | 
					
						
							| 
									
										
										
										
											2018-09-06 20:57:05 -07:00
										 |  |  | shift $((OPTIND - 1)) | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-27 22:42:08 +00:00
										 |  |  | [[ ${#zones[@]} -gt 0 ]] || zones+=("$(cloud_DefaultZone)") | 
					
						
							| 
									
										
										
										
											2019-03-27 22:19:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-06 20:57:05 -07:00
										 |  |  | [[ -z $1 ]] || usage "Unexpected argument: $1" | 
					
						
							| 
									
										
										
										
											2018-11-07 18:47:52 -08:00
										 |  |  | if [[ $cloudProvider = ec2 ]]; then | 
					
						
							|  |  |  |   # EC2 keys can't be retrieved from running instances like GCE keys can so save | 
					
						
							|  |  |  |   # EC2 keys in the user's home directory so |./ec2.sh config| can at least be | 
					
						
							|  |  |  |   # used on the same host that ran |./ec2.sh create| . | 
					
						
							|  |  |  |   sshPrivateKey="$HOME/.ssh/solana-net-id_$prefix" | 
					
						
							|  |  |  | else | 
					
						
							|  |  |  |   sshPrivateKey="$netConfigDir/id_$prefix" | 
					
						
							|  |  |  | fi | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-07 10:03:40 -08:00
										 |  |  | case $cloudProvider in | 
					
						
							|  |  |  | gce) | 
					
						
							|  |  |  |   ;; | 
					
						
							|  |  |  | ec2) | 
					
						
							|  |  |  |   ;; | 
					
						
							| 
									
										
										
										
											2019-04-23 16:41:45 -06:00
										 |  |  | azure) | 
					
						
							|  |  |  |   ;; | 
					
						
							| 
									
										
										
										
											2018-11-07 10:03:40 -08:00
										 |  |  | *) | 
					
						
							|  |  |  |   echo "Error: Unknown cloud provider: $cloudProvider" | 
					
						
							|  |  |  |   ;; | 
					
						
							|  |  |  | esac | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  | # cloud_ForEachInstance [cmd] [extra args to cmd] | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # Execute a command for each element in the `instances` array | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | #   cmd   - The command to execute on each instance | 
					
						
							|  |  |  | #           The command will receive arguments followed by any | 
					
						
							| 
									
										
										
										
											2019-04-23 16:41:45 -06:00
										 |  |  | #           additional arguments supplied to cloud_ForEachInstance: | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  | #               name     - name of the instance | 
					
						
							|  |  |  | #               publicIp - The public IP address of this instance | 
					
						
							| 
									
										
										
										
											2019-04-23 16:41:45 -06:00
										 |  |  | #               privateIp - The private IP address of this instance | 
					
						
							| 
									
										
										
										
											2019-04-28 19:50:02 -07:00
										 |  |  | #               zone     - Zone of this instance | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  | #               count    - Monotonically increasing count for each | 
					
						
							|  |  |  | #                          invocation of cmd, starting at 1 | 
					
						
							|  |  |  | #               ...      - Extra args to cmd.. | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | cloud_ForEachInstance() { | 
					
						
							|  |  |  |   declare cmd="$1" | 
					
						
							|  |  |  |   shift | 
					
						
							|  |  |  |   [[ -n $cmd ]] || { echo cloud_ForEachInstance: cmd not specified; exit 1; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   declare count=1 | 
					
						
							|  |  |  |   for info in "${instances[@]}"; do | 
					
						
							|  |  |  |     declare name publicIp privateIp | 
					
						
							| 
									
										
										
										
											2019-03-27 23:16:30 +00:00
										 |  |  |     IFS=: read -r name publicIp privateIp zone < <(echo "$info") | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-28 19:50:02 -07:00
										 |  |  |     eval "$cmd" "$name" "$publicIp" "$privateIp" "$zone" "$count" "$@" | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  |     count=$((count + 1)) | 
					
						
							|  |  |  |   done | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-28 19:50:02 -07:00
										 |  |  | # Given a cloud provider zone, return an approximate lat,long location for the | 
					
						
							|  |  |  | # data center.  Normal geoip lookups for cloud provider IP addresses are | 
					
						
							|  |  |  | # sometimes widely inaccurate. | 
					
						
							|  |  |  | zoneLocation() { | 
					
						
							|  |  |  |   declare zone="$1" | 
					
						
							|  |  |  |   case "$zone" in | 
					
						
							|  |  |  |   us-west1*) | 
					
						
							|  |  |  |     echo "[45.5946, -121.1787]" | 
					
						
							|  |  |  |     ;; | 
					
						
							|  |  |  |   us-central1*) | 
					
						
							|  |  |  |     echo "[41.2619, -95.8608]" | 
					
						
							|  |  |  |     ;; | 
					
						
							|  |  |  |   us-east1*) | 
					
						
							|  |  |  |     echo "[33.1960, -80.0131]" | 
					
						
							|  |  |  |     ;; | 
					
						
							|  |  |  |   asia-east2*) | 
					
						
							|  |  |  |     echo "[22.3193, 114.1694]" | 
					
						
							|  |  |  |     ;; | 
					
						
							|  |  |  |   asia-northeast1*) | 
					
						
							|  |  |  |     echo "[35.6762, 139.6503]" | 
					
						
							|  |  |  |     ;; | 
					
						
							|  |  |  |   asia-northeast2*) | 
					
						
							|  |  |  |     echo "[34.6937, 135.5023]" | 
					
						
							|  |  |  |     ;; | 
					
						
							|  |  |  |   asia-south1*) | 
					
						
							|  |  |  |     echo "[19.0760, 72.8777]" | 
					
						
							|  |  |  |     ;; | 
					
						
							|  |  |  |   asia-southeast1*) | 
					
						
							|  |  |  |     echo "[1.3404, 103.7090]" | 
					
						
							|  |  |  |     ;; | 
					
						
							|  |  |  |   australia-southeast1*) | 
					
						
							|  |  |  |     echo "[-33.8688, 151.2093]" | 
					
						
							|  |  |  |     ;; | 
					
						
							|  |  |  |   europe-north1*) | 
					
						
							|  |  |  |     echo "[60.5693, 27.1878]" | 
					
						
							|  |  |  |     ;; | 
					
						
							|  |  |  |   europe-west2*) | 
					
						
							|  |  |  |     echo "[51.5074, -0.1278]" | 
					
						
							|  |  |  |     ;; | 
					
						
							|  |  |  |   europe-west3*) | 
					
						
							|  |  |  |     echo "[50.1109, 8.6821]" | 
					
						
							|  |  |  |     ;; | 
					
						
							|  |  |  |   europe-west4*) | 
					
						
							|  |  |  |     echo "[53.4386, 6.8355]" | 
					
						
							|  |  |  |     ;; | 
					
						
							|  |  |  |   europe-west6*) | 
					
						
							|  |  |  |     echo "[47.3769, 8.5417]" | 
					
						
							|  |  |  |     ;; | 
					
						
							|  |  |  |   northamerica-northeast1*) | 
					
						
							|  |  |  |     echo "[45.5017, -73.5673]" | 
					
						
							|  |  |  |     ;; | 
					
						
							|  |  |  |   southamerica-east1*) | 
					
						
							|  |  |  |     echo "[-23.5505, -46.6333]" | 
					
						
							|  |  |  |     ;; | 
					
						
							|  |  |  |   *) | 
					
						
							|  |  |  |     ;; | 
					
						
							|  |  |  |   esac | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-03 18:15:55 -10:00
										 |  |  | prepareInstancesAndWriteConfigFile() { | 
					
						
							| 
									
										
										
										
											2018-09-06 13:00:01 -07:00
										 |  |  |   $metricsWriteDatapoint "testnet-deploy net-config-begin=1" | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-01 22:54:41 +00:00
										 |  |  |   if $externalNodes; then | 
					
						
							|  |  |  |     echo "Appending to existing config file" | 
					
						
							|  |  |  |     echo "externalNodeSshKey=$sshPrivateKey" >> "$configFile" | 
					
						
							|  |  |  |   else | 
					
						
							| 
									
										
										
										
											2019-04-28 19:50:02 -07:00
										 |  |  |     rm -f "$geoipConfigFile" | 
					
						
							| 
									
										
										
										
											2019-04-01 22:54:41 +00:00
										 |  |  |     cat >> "$configFile" <<EOF | 
					
						
							| 
									
										
										
										
											2018-09-04 22:21:58 -07:00
										 |  |  | # autogenerated at $(date) | 
					
						
							|  |  |  | netBasename=$prefix | 
					
						
							|  |  |  | publicNetwork=$publicNetwork | 
					
						
							| 
									
										
										
										
											2018-09-08 19:19:12 -07:00
										 |  |  | sshPrivateKey=$sshPrivateKey | 
					
						
							| 
									
										
										
										
											2018-12-05 17:33:32 -08:00
										 |  |  | leaderRotation=$leaderRotation | 
					
						
							| 
									
										
										
										
											2018-09-04 22:21:58 -07:00
										 |  |  | EOF | 
					
						
							| 
									
										
										
										
											2019-04-01 22:54:41 +00:00
										 |  |  |   fi | 
					
						
							| 
									
										
										
										
											2019-04-28 19:50:02 -07:00
										 |  |  |   touch "$geoipConfigFile" | 
					
						
							| 
									
										
										
										
											2018-09-03 18:15:55 -10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-08 19:19:12 -07:00
										 |  |  |   buildSshOptions | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   recordInstanceIp() { | 
					
						
							|  |  |  |     declare name="$1" | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  |     declare publicIp="$2" | 
					
						
							|  |  |  |     declare privateIp="$3" | 
					
						
							| 
									
										
										
										
											2019-04-28 19:50:02 -07:00
										 |  |  |     declare zone="$4" | 
					
						
							|  |  |  |     #declare index="$5" | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-28 19:50:02 -07:00
										 |  |  |     declare failOnFailure="$6" | 
					
						
							|  |  |  |     declare arrayName="$7" | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-28 19:50:02 -07:00
										 |  |  |     # This check should eventually be moved to cloud provider specific script | 
					
						
							| 
									
										
										
										
											2019-04-24 16:23:26 -07:00
										 |  |  |     if [ "$publicIp" = "TERMINATED" ] || [ "$privateIp" = "TERMINATED" ]; then | 
					
						
							|  |  |  |       if $failOnFailure; then | 
					
						
							|  |  |  |         exit 1 | 
					
						
							|  |  |  |       else | 
					
						
							|  |  |  |         return 0 | 
					
						
							|  |  |  |       fi | 
					
						
							|  |  |  |     fi | 
					
						
							| 
									
										
										
										
											2018-09-08 19:19:12 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-24 16:23:26 -07:00
										 |  |  |     ok=true | 
					
						
							| 
									
										
										
										
											2018-09-08 19:19:12 -07:00
										 |  |  |     echo "Waiting for $name to finish booting..." | 
					
						
							|  |  |  |     ( | 
					
						
							| 
									
										
										
										
											2018-11-07 15:11:47 -08:00
										 |  |  |       set -x +e | 
					
						
							| 
									
										
										
										
											2019-04-28 19:50:02 -07:00
										 |  |  |       for i in $(seq 1 30); do | 
					
						
							| 
									
										
										
										
											2019-04-24 16:23:26 -07:00
										 |  |  |         timeout --preserve-status --foreground 20s ssh "${sshOptions[@]}" "$publicIp" "ls -l /.instance-startup-complete" | 
					
						
							| 
									
										
										
										
											2018-11-07 15:11:47 -08:00
										 |  |  |         ret=$? | 
					
						
							|  |  |  |         if [[ $ret -eq 0 ]]; then | 
					
						
							| 
									
										
										
										
											2019-04-24 16:23:26 -07:00
										 |  |  |           echo "$name has booted." | 
					
						
							| 
									
										
										
										
											2018-11-06 19:23:20 -08:00
										 |  |  |           exit 0 | 
					
						
							| 
									
										
										
										
											2018-09-08 19:19:12 -07:00
										 |  |  |         fi | 
					
						
							|  |  |  |         sleep 2 | 
					
						
							|  |  |  |         echo "Retry $i..." | 
					
						
							|  |  |  |       done | 
					
						
							| 
									
										
										
										
											2018-11-06 19:23:20 -08:00
										 |  |  |       echo "$name failed to boot." | 
					
						
							|  |  |  |       exit 1 | 
					
						
							| 
									
										
										
										
											2019-04-24 16:23:26 -07:00
										 |  |  |     ) || ok=false | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if ! $ok; then | 
					
						
							|  |  |  |       if $failOnFailure; then | 
					
						
							|  |  |  |         exit 1 | 
					
						
							|  |  |  |       fi | 
					
						
							|  |  |  |     else | 
					
						
							| 
									
										
										
										
											2019-04-28 19:50:02 -07:00
										 |  |  |       { | 
					
						
							|  |  |  |         echo "$arrayName+=($publicIp)  # $name" | 
					
						
							|  |  |  |         echo "${arrayName}Private+=($privateIp)  # $name" | 
					
						
							|  |  |  |         echo "${arrayName}Zone+=($zone)  # $name" | 
					
						
							|  |  |  |       } >> "$configFile" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       declare latlng= | 
					
						
							|  |  |  |       latlng=$(zoneLocation "$zone") | 
					
						
							|  |  |  |       if [[ -n $latlng ]]; then | 
					
						
							|  |  |  |         echo "$publicIp: $latlng" >> "$geoipConfigFile" | 
					
						
							|  |  |  |       fi | 
					
						
							| 
									
										
										
										
											2019-04-24 16:23:26 -07:00
										 |  |  |     fi | 
					
						
							| 
									
										
										
										
											2018-09-08 19:19:12 -07:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-28 19:50:02 -07:00
										 |  |  |   fetchPrivateKey() { | 
					
						
							| 
									
										
										
										
											2019-04-01 22:54:41 +00:00
										 |  |  |     ( | 
					
						
							|  |  |  |       declare nodeName | 
					
						
							|  |  |  |       declare nodeIp | 
					
						
							|  |  |  |       declare nodeZone | 
					
						
							|  |  |  |       IFS=: read -r nodeName nodeIp _ nodeZone < <(echo "${instances[0]}") | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-23 16:41:45 -06:00
										 |  |  |       # Make sure the machine is alive or pingable | 
					
						
							|  |  |  |       timeout_sec=90 | 
					
						
							|  |  |  |       cloud_WaitForInstanceReady "$nodeName" "$nodeIp" "$nodeZone" "$timeout_sec" | 
					
						
							| 
									
										
										
										
											2019-04-01 22:54:41 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |       if [[ ! -r $sshPrivateKey ]]; then | 
					
						
							|  |  |  |         echo "Fetching $sshPrivateKey from $nodeName" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         # Try to scp in a couple times, sshd may not yet be up even though the | 
					
						
							|  |  |  |         # machine can be pinged... | 
					
						
							|  |  |  |         set -x -o pipefail | 
					
						
							|  |  |  |         for i in $(seq 1 30); do | 
					
						
							|  |  |  |           if cloud_FetchFile "$nodeName" "$nodeIp" /solana-id_ecdsa "$sshPrivateKey" "$nodeZone"; then | 
					
						
							| 
									
										
										
										
											2019-04-28 19:50:02 -07:00
										 |  |  |             if cloud_FetchFile "$nodeName" "$nodeIp" /solana-id_ecdsa.pub "$sshPrivateKey.pub" "$nodeZone"; then | 
					
						
							|  |  |  |               break | 
					
						
							|  |  |  |             fi | 
					
						
							| 
									
										
										
										
											2019-04-01 22:54:41 +00:00
										 |  |  |           fi | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           sleep 1 | 
					
						
							|  |  |  |           echo "Retry $i..." | 
					
						
							|  |  |  |         done | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         chmod 400 "$sshPrivateKey" | 
					
						
							|  |  |  |         ls -l "$sshPrivateKey" | 
					
						
							|  |  |  |       fi | 
					
						
							|  |  |  |     ) | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-28 19:50:02 -07:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if $externalNodes; then | 
					
						
							|  |  |  |     echo "Bootstrap leader is already configured" | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     echo "Looking for bootstrap leader instance..." | 
					
						
							|  |  |  |     cloud_FindInstance "$prefix-bootstrap-leader" | 
					
						
							|  |  |  |     [[ ${#instances[@]} -eq 1 ]] || { | 
					
						
							|  |  |  |       echo "Unable to find bootstrap leader" | 
					
						
							|  |  |  |       exit 1 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     fetchPrivateKey | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-01 22:54:41 +00:00
										 |  |  |     echo "fullnodeIpList=()" >> "$configFile" | 
					
						
							|  |  |  |     echo "fullnodeIpListPrivate=()" >> "$configFile" | 
					
						
							| 
									
										
										
										
											2019-04-24 16:23:26 -07:00
										 |  |  |     cloud_ForEachInstance recordInstanceIp true fullnodeIpList | 
					
						
							| 
									
										
										
										
											2019-04-01 22:54:41 +00:00
										 |  |  |   fi | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 17:38:18 -07:00
										 |  |  |   if [[ $additionalFullNodeCount -gt 0 ]]; then | 
					
						
							|  |  |  |     for zone in "${zones[@]}"; do | 
					
						
							| 
									
										
										
										
											2019-04-19 17:46:14 -07:00
										 |  |  |       echo "Looking for additional fullnode instances in $zone ..." | 
					
						
							| 
									
										
										
										
											2019-04-17 17:38:18 -07:00
										 |  |  |       cloud_FindInstances "$prefix-$zone-fullnode" | 
					
						
							| 
									
										
										
										
											2019-04-29 21:38:03 -07:00
										 |  |  |       if [[ ${#instances[@]} -gt 0 ]]; then | 
					
						
							|  |  |  |         fetchPrivateKey | 
					
						
							|  |  |  |         cloud_ForEachInstance recordInstanceIp "$failOnValidatorBootupFailure" fullnodeIpList | 
					
						
							|  |  |  |       else | 
					
						
							| 
									
										
										
										
											2019-04-17 17:38:18 -07:00
										 |  |  |         echo "Unable to find additional fullnodes" | 
					
						
							| 
									
										
										
										
											2019-04-29 21:38:03 -07:00
										 |  |  |         if $failOnValidatorBootupFailure; then | 
					
						
							|  |  |  |           exit 1 | 
					
						
							|  |  |  |         fi | 
					
						
							|  |  |  |       fi | 
					
						
							| 
									
										
										
										
											2019-04-17 17:38:18 -07:00
										 |  |  |     done | 
					
						
							|  |  |  |   fi | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-01 22:54:41 +00:00
										 |  |  |   if $externalNodes; then | 
					
						
							|  |  |  |     echo "Let's not reset the current client configuration" | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     echo "clientIpList=()" >> "$configFile" | 
					
						
							|  |  |  |     echo "clientIpListPrivate=()" >> "$configFile" | 
					
						
							|  |  |  |   fi | 
					
						
							| 
									
										
										
										
											2018-12-05 16:40:08 -08:00
										 |  |  |   echo "Looking for client bencher instances..." | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  |   cloud_FindInstances "$prefix-client" | 
					
						
							| 
									
										
										
										
											2018-09-04 22:46:55 -07:00
										 |  |  |   [[ ${#instances[@]} -eq 0 ]] || { | 
					
						
							| 
									
										
										
										
											2019-04-24 16:23:26 -07:00
										 |  |  |     cloud_ForEachInstance recordInstanceIp true clientIpList | 
					
						
							| 
									
										
										
										
											2018-09-04 22:46:55 -07:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-01 22:54:41 +00:00
										 |  |  |   if $externalNodes; then | 
					
						
							|  |  |  |     echo "Let's not reset the current blockstream configuration" | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     echo "blockstreamerIpList=()" >> "$configFile" | 
					
						
							|  |  |  |     echo "blockstreamerIpListPrivate=()" >> "$configFile" | 
					
						
							|  |  |  |   fi | 
					
						
							| 
									
										
										
										
											2019-02-21 16:35:26 -07:00
										 |  |  |   echo "Looking for blockstreamer instances..." | 
					
						
							|  |  |  |   cloud_FindInstances "$prefix-blockstreamer" | 
					
						
							| 
									
										
										
										
											2019-02-17 09:48:27 -08:00
										 |  |  |   [[ ${#instances[@]} -eq 0 ]] || { | 
					
						
							| 
									
										
										
										
											2019-04-24 16:23:26 -07:00
										 |  |  |     cloud_ForEachInstance recordInstanceIp true blockstreamerIpList | 
					
						
							| 
									
										
										
										
											2019-02-17 09:48:27 -08:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  |   echo "Wrote $configFile" | 
					
						
							| 
									
										
										
										
											2018-09-06 12:14:04 -07:00
										 |  |  |   $metricsWriteDatapoint "testnet-deploy net-config-complete=1" | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  | delete() { | 
					
						
							| 
									
										
										
										
											2018-09-06 13:00:01 -07:00
										 |  |  |   $metricsWriteDatapoint "testnet-deploy net-delete-begin=1" | 
					
						
							| 
									
										
										
										
											2018-09-06 12:14:04 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-09 09:42:09 -08:00
										 |  |  |   # Delete the bootstrap leader first to prevent unusual metrics on the dashboard | 
					
						
							| 
									
										
										
										
											2018-12-05 16:40:08 -08:00
										 |  |  |   # during shutdown (only applicable when leader rotation is disabled). | 
					
						
							| 
									
										
										
										
											2018-09-07 08:56:43 -07:00
										 |  |  |   # TODO: It would be better to fully cut-off metrics reporting before any | 
					
						
							|  |  |  |   # instances are deleted. | 
					
						
							| 
									
										
										
										
											2019-03-27 22:19:55 +00:00
										 |  |  |   filters=("$prefix-bootstrap-leader") | 
					
						
							|  |  |  |   for zone in "${zones[@]}"; do | 
					
						
							|  |  |  |     filters+=("$prefix-$zone") | 
					
						
							|  |  |  |   done | 
					
						
							|  |  |  |   # Filter for all other nodes (client, blockstreamer) | 
					
						
							|  |  |  |   filters+=("$prefix-") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   for filter in  "${filters[@]}"; do | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  |     echo "Searching for instances: $filter" | 
					
						
							|  |  |  |     cloud_FindInstances "$filter" | 
					
						
							| 
									
										
										
										
											2018-09-07 08:56:43 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if [[ ${#instances[@]} -eq 0 ]]; then | 
					
						
							|  |  |  |       echo "No instances found matching '$filter'" | 
					
						
							|  |  |  |     else | 
					
						
							| 
									
										
										
										
											2019-04-19 17:46:14 -07:00
										 |  |  |       cloud_DeleteInstances true & | 
					
						
							| 
									
										
										
										
											2018-09-07 08:56:43 -07:00
										 |  |  |     fi | 
					
						
							|  |  |  |   done | 
					
						
							| 
									
										
										
										
											2019-04-19 17:46:14 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   wait | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-01 22:54:41 +00:00
										 |  |  |   if $externalNodes; then | 
					
						
							|  |  |  |     echo "Let's not delete the current configuration file" | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     rm -f "$configFile" | 
					
						
							|  |  |  |   fi | 
					
						
							| 
									
										
										
										
											2018-09-06 12:14:04 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   $metricsWriteDatapoint "testnet-deploy net-delete-complete=1" | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | case $command in | 
					
						
							|  |  |  | delete) | 
					
						
							|  |  |  |   delete | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  |   ;; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | create) | 
					
						
							| 
									
										
										
										
											2018-12-05 16:40:08 -08:00
										 |  |  |   [[ -n $additionalFullNodeCount ]] || usage "Need number of nodes" | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   delete | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-06 13:00:01 -07:00
										 |  |  |   $metricsWriteDatapoint "testnet-deploy net-create-begin=1" | 
					
						
							| 
									
										
										
										
											2018-09-06 12:14:04 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-08 19:19:12 -07:00
										 |  |  |   rm -rf "$sshPrivateKey"{,.pub} | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   # Note: using rsa because |aws ec2 import-key-pair| seems to fail for ecdsa | 
					
						
							|  |  |  |   ssh-keygen -t rsa -N '' -f "$sshPrivateKey" | 
					
						
							| 
									
										
										
										
											2018-09-08 19:19:12 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-08 10:38:32 -07:00
										 |  |  |   printNetworkInfo() { | 
					
						
							|  |  |  |     cat <<EOF | 
					
						
							|  |  |  | ======================================================================================== | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Network composition: | 
					
						
							| 
									
										
										
										
											2018-12-09 09:42:09 -08:00
										 |  |  |   Bootstrap leader = $bootstrapLeaderMachineType (GPU=$enableGpu) | 
					
						
							|  |  |  |   Additional fullnodes = $additionalFullNodeCount x $fullNodeMachineType | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  |   Client(s) = $clientNodeCount x $clientMachineType | 
					
						
							| 
									
										
										
										
											2019-02-21 16:35:26 -07:00
										 |  |  |   Blockstreamer = $blockstreamer | 
					
						
							| 
									
										
										
										
											2018-09-08 10:38:32 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-05 17:33:32 -08:00
										 |  |  | Leader rotation: $leaderRotation | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-08 10:38:32 -07:00
										 |  |  | ======================================================================================== | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | EOF | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   printNetworkInfo | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  |   declare startupScript="$netConfigDir"/instance-startup-script.sh | 
					
						
							| 
									
										
										
										
											2018-09-08 10:38:32 -07:00
										 |  |  |   cat > "$startupScript" <<EOF | 
					
						
							| 
									
										
										
										
											2018-11-11 08:19:04 -08:00
										 |  |  | #!/usr/bin/env bash
 | 
					
						
							| 
									
										
										
										
											2018-09-08 10:38:32 -07:00
										 |  |  | # autogenerated at $(date) | 
					
						
							| 
									
										
										
										
											2018-11-11 09:25:59 -08:00
										 |  |  | set -ex | 
					
						
							| 
									
										
										
										
											2018-09-08 10:38:32 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | cat > /etc/motd <<EOM | 
					
						
							|  |  |  | !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   This instance has not been fully configured. | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   See startup script log messages in /var/log/syslog for status: | 
					
						
							|  |  |  |     $ sudo cat /var/log/syslog | egrep \\(startup-script\\|cloud-init\) | 
					
						
							| 
									
										
										
										
											2018-09-08 10:38:32 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-08 19:19:12 -07:00
										 |  |  |   To block until setup is complete, run: | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  |     $ until [[ -f /.instance-startup-complete ]]; do sleep 1; done | 
					
						
							| 
									
										
										
										
											2018-09-08 19:19:12 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-08 10:38:32 -07:00
										 |  |  | !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 
					
						
							|  |  |  | EOM | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-08 19:19:12 -07:00
										 |  |  | # Place the generated private key at /solana-id_ecdsa so it's retrievable by anybody | 
					
						
							|  |  |  | # who is able to log into this machine | 
					
						
							|  |  |  | cat > /solana-id_ecdsa <<EOK | 
					
						
							|  |  |  | $(cat "$sshPrivateKey") | 
					
						
							|  |  |  | EOK | 
					
						
							|  |  |  | cat > /solana-id_ecdsa.pub <<EOK | 
					
						
							|  |  |  | $(cat "$sshPrivateKey.pub") | 
					
						
							|  |  |  | EOK | 
					
						
							|  |  |  | chmod 444 /solana-id_ecdsa | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-08 10:38:32 -07:00
										 |  |  | USER=\$(id -un) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | $( | 
					
						
							|  |  |  |   cd "$here"/scripts/ | 
					
						
							|  |  |  |   cat \
 | 
					
						
							|  |  |  |     disable-background-upgrades.sh \
 | 
					
						
							| 
									
										
										
										
											2018-09-08 19:19:12 -07:00
										 |  |  |     create-solana-user.sh \
 | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  |     add-solana-user-authorized_keys.sh \
 | 
					
						
							| 
									
										
										
										
											2018-09-08 10:38:32 -07:00
										 |  |  |     install-earlyoom.sh \
 | 
					
						
							|  |  |  |     install-libssl-compatability.sh \
 | 
					
						
							| 
									
										
										
										
											2019-02-15 20:17:30 -08:00
										 |  |  |     install-nodejs.sh \
 | 
					
						
							|  |  |  |     install-redis.sh \
 | 
					
						
							| 
									
										
										
										
											2018-09-12 16:22:22 -07:00
										 |  |  |     install-rsync.sh \
 | 
					
						
							| 
									
										
										
										
											2018-10-30 09:17:35 -07:00
										 |  |  |     network-config.sh \
 | 
					
						
							| 
									
										
										
										
											2018-11-07 17:42:29 -08:00
										 |  |  |     remove-docker-interface.sh \
 | 
					
						
							| 
									
										
										
										
											2018-11-06 19:23:20 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-21 11:43:52 -08:00
										 |  |  |     if "$enableGpu"; then | 
					
						
							|  |  |  |       cat enable-nvidia-persistence-mode.sh | 
					
						
							|  |  |  |     fi | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-08 10:38:32 -07:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | cat > /etc/motd <<EOM | 
					
						
							|  |  |  | $(printNetworkInfo) | 
					
						
							|  |  |  | EOM | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  | touch /.instance-startup-complete | 
					
						
							| 
									
										
										
										
											2018-09-08 19:19:12 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-08 10:38:32 -07:00
										 |  |  | EOF | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-21 16:35:26 -07:00
										 |  |  |   if $blockstreamer; then | 
					
						
							|  |  |  |     blockstreamerAddress=$customAddress | 
					
						
							| 
									
										
										
										
											2019-02-17 09:48:27 -08:00
										 |  |  |   else | 
					
						
							|  |  |  |     bootstrapLeaderAddress=$customAddress | 
					
						
							|  |  |  |   fi | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-27 22:19:55 +00:00
										 |  |  |   for zone in "${zones[@]}"; do | 
					
						
							|  |  |  |     cloud_Initialize "$prefix" "$zone" | 
					
						
							|  |  |  |   done | 
					
						
							| 
									
										
										
										
											2019-02-18 17:43:03 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-01 22:54:41 +00:00
										 |  |  |   if $externalNodes; then | 
					
						
							|  |  |  |     echo "Bootstrap leader is already configured" | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     cloud_CreateInstances "$prefix" "$prefix-bootstrap-leader" 1 \
 | 
					
						
							|  |  |  |       "$enableGpu" "$bootstrapLeaderMachineType" "${zones[0]}" "$fullNodeBootDiskSizeInGb" \
 | 
					
						
							|  |  |  |       "$startupScript" "$bootstrapLeaderAddress" "$bootDiskType" | 
					
						
							|  |  |  |   fi | 
					
						
							| 
									
										
										
										
											2018-09-05 09:31:50 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 17:38:18 -07:00
										 |  |  |   if [[ $additionalFullNodeCount -gt 0 ]]; then | 
					
						
							|  |  |  |     num_zones=${#zones[@]} | 
					
						
							|  |  |  |     numNodesPerZone=$((additionalFullNodeCount / num_zones)) | 
					
						
							|  |  |  |     numLeftOverNodes=$((additionalFullNodeCount % num_zones)) | 
					
						
							|  |  |  |     for ((i=0; i < "$num_zones"; i++)); do | 
					
						
							|  |  |  |       zone=${zones[i]} | 
					
						
							|  |  |  |       if [[ $i -eq $((num_zones - 1)) ]]; then | 
					
						
							|  |  |  |         numNodesPerZone=$((numNodesPerZone + numLeftOverNodes)) | 
					
						
							|  |  |  |       fi | 
					
						
							|  |  |  |       cloud_CreateInstances "$prefix" "$prefix-$zone-fullnode" "$numNodesPerZone" \
 | 
					
						
							|  |  |  |         "$enableGpu" "$fullNodeMachineType" "$zone" "$fullNodeBootDiskSizeInGb" \
 | 
					
						
							|  |  |  |         "$startupScript" "" "$bootDiskType" & | 
					
						
							|  |  |  |     done | 
					
						
							| 
									
										
										
										
											2018-09-08 10:38:32 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 17:38:18 -07:00
										 |  |  |     wait | 
					
						
							|  |  |  |   fi | 
					
						
							| 
									
										
										
										
											2019-04-07 08:13:48 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-06 10:34:24 -07:00
										 |  |  |   if [[ $clientNodeCount -gt 0 ]]; then | 
					
						
							| 
									
										
										
										
											2018-09-16 14:46:08 -07:00
										 |  |  |     cloud_CreateInstances "$prefix" "$prefix-client" "$clientNodeCount" \
 | 
					
						
							| 
									
										
										
										
											2019-03-27 22:19:55 +00:00
										 |  |  |       "$enableGpu" "$clientMachineType" "${zones[0]}" "$clientBootDiskSizeInGb" \
 | 
					
						
							| 
									
										
										
										
											2018-09-22 16:43:47 -07:00
										 |  |  |       "$startupScript" "" "$bootDiskType" | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  |   fi | 
					
						
							| 
									
										
										
										
											2018-08-29 08:13:35 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-21 16:35:26 -07:00
										 |  |  |   if $blockstreamer; then | 
					
						
							|  |  |  |     cloud_CreateInstances "$prefix" "$prefix-blockstreamer" "1" \
 | 
					
						
							| 
									
										
										
										
											2019-03-27 22:19:55 +00:00
										 |  |  |       "$enableGpu" "$blockstreamerMachineType" "${zones[0]}" "$fullNodeBootDiskSizeInGb" \
 | 
					
						
							| 
									
										
										
										
											2019-02-21 16:35:26 -07:00
										 |  |  |       "$startupScript" "$blockstreamerAddress" "$bootDiskType" | 
					
						
							| 
									
										
										
										
											2019-02-17 09:48:27 -08:00
										 |  |  |   fi | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-06 12:14:04 -07:00
										 |  |  |   $metricsWriteDatapoint "testnet-deploy net-create-complete=1" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-03 18:15:55 -10:00
										 |  |  |   prepareInstancesAndWriteConfigFile | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  |   ;; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | config) | 
					
						
							| 
									
										
										
										
											2018-09-03 18:15:55 -10:00
										 |  |  |   prepareInstancesAndWriteConfigFile | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  |   ;; | 
					
						
							| 
									
										
										
										
											2019-01-16 09:38:29 -08:00
										 |  |  | info) | 
					
						
							|  |  |  |   loadConfigFile | 
					
						
							|  |  |  |   printNode() { | 
					
						
							|  |  |  |     declare nodeType=$1 | 
					
						
							|  |  |  |     declare ip=$2 | 
					
						
							|  |  |  |     declare ipPrivate=$3 | 
					
						
							| 
									
										
										
										
											2019-04-28 19:50:02 -07:00
										 |  |  |     declare zone=$4 | 
					
						
							|  |  |  |     printf "  %-16s | %-15s | %-15s | %s\n" "$nodeType" "$ip" "$ipPrivate" "$zone" | 
					
						
							| 
									
										
										
										
											2019-01-16 09:38:29 -08:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-28 19:50:02 -07:00
										 |  |  |   printNode "Node Type" "Public IP" "Private IP" "Zone" | 
					
						
							|  |  |  |   echo "-------------------+-----------------+-----------------+--------------" | 
					
						
							| 
									
										
										
										
											2019-01-16 09:38:29 -08:00
										 |  |  |   nodeType=bootstrap-leader | 
					
						
							|  |  |  |   for i in $(seq 0 $(( ${#fullnodeIpList[@]} - 1)) ); do | 
					
						
							|  |  |  |     ipAddress=${fullnodeIpList[$i]} | 
					
						
							|  |  |  |     ipAddressPrivate=${fullnodeIpListPrivate[$i]} | 
					
						
							| 
									
										
										
										
											2019-04-28 19:50:02 -07:00
										 |  |  |     zone=${fullnodeIpListZone[$i]} | 
					
						
							|  |  |  |     printNode $nodeType "$ipAddress" "$ipAddressPrivate" "$zone" | 
					
						
							| 
									
										
										
										
											2019-01-16 09:38:29 -08:00
										 |  |  |     nodeType=fullnode | 
					
						
							|  |  |  |   done | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   for i in $(seq 0 $(( ${#clientIpList[@]} - 1)) ); do | 
					
						
							|  |  |  |     ipAddress=${clientIpList[$i]} | 
					
						
							|  |  |  |     ipAddressPrivate=${clientIpListPrivate[$i]} | 
					
						
							| 
									
										
										
										
											2019-04-28 19:50:02 -07:00
										 |  |  |     zone=${clientIpListZone[$i]} | 
					
						
							|  |  |  |     printNode bench-tps "$ipAddress" "$ipAddressPrivate" "$zone" | 
					
						
							| 
									
										
										
										
											2019-01-16 09:38:29 -08:00
										 |  |  |   done | 
					
						
							| 
									
										
										
										
											2019-02-17 09:48:27 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-21 16:35:26 -07:00
										 |  |  |   for i in $(seq 0 $(( ${#blockstreamerIpList[@]} - 1)) ); do | 
					
						
							|  |  |  |     ipAddress=${blockstreamerIpList[$i]} | 
					
						
							|  |  |  |     ipAddressPrivate=${blockstreamerIpListPrivate[$i]} | 
					
						
							| 
									
										
										
										
											2019-04-28 19:50:02 -07:00
										 |  |  |     zone=${blockstreamerIpListZone[$i]} | 
					
						
							|  |  |  |     printNode blockstreamer "$ipAddress" "$ipAddressPrivate" "$zone" | 
					
						
							| 
									
										
										
										
											2019-02-17 09:48:27 -08:00
										 |  |  |   done | 
					
						
							| 
									
										
										
										
											2019-01-16 09:38:29 -08:00
										 |  |  |   ;; | 
					
						
							| 
									
										
										
										
											2018-08-28 10:19:33 -07:00
										 |  |  | *) | 
					
						
							|  |  |  |   usage "Unknown command: $command" | 
					
						
							|  |  |  | esac |