1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53
|
#!/bin/bash
DIR=$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )
if [ "$1" == "" ]; then
echo "Usage: $0 <config.sh file>"
exit 1;
fi
source ${DIR}/config.sh $1
source ${DIR}/util.sh
set -e
GCLOUD="gcloud"
Header "Creating mirror persistent disks..."
for i in `seq 0 $((${MIRROR_NUM_REPLICAS} - 1))`; do
echo "Creating disk ${MIRROR_DISKS[${i}]}..."
${GCLOUD} compute disks create -q ${MIRROR_DISKS[${i}]} \
--zone ${MIRROR_ZONES[${i}]} \
--size=${MIRROR_DISK_SIZE} &
done
wait
for i in `seq 0 $((${MIRROR_NUM_REPLICAS} - 1))`; do
echo "Waiting for disk ${MIRROR_DISKS[${i}]}..."
WaitForStatus disks ${MIRROR_DISKS[${i}]} ${MIRROR_ZONES[${i}]} READY &
done
wait
MANIFEST=/tmp/mirror_container.yaml
Header "Creating mirror instances..."
for i in `seq 0 $((${MIRROR_NUM_REPLICAS} - 1))`; do
echo "Creating instance ${MIRROR_MACHINES[$i]}"
echo "${MIRROR_META[${i}]}" > ${MANIFEST}.${i}
${GCLOUD} compute instances create -q ${MIRROR_MACHINES[${i}]} \
--zone ${MIRROR_ZONES[${i}]} \
--machine-type ${MIRROR_MACHINE_TYPE} \
--image container-vm \
--disk name=${MIRROR_DISKS[${i}]},mode=rw,boot=no,auto-delete=yes \
--tags mirror-node \
--scopes "monitoring,storage-ro,compute-ro,logging-write" \
--metadata-from-file startup-script=${DIR}/node_init.sh,google-container-manifest=${MANIFEST}.${i} &
done
wait
for i in `seq 0 $((${MIRROR_NUM_REPLICAS} - 1))`; do
echo "Waiting for instance ${MIRROR_MACHINES[${i}]}..."
WaitForStatus instances ${MIRROR_MACHINES[${i}]} ${MIRROR_ZONES[${i}]} RUNNING &
done
wait
|