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-file>"
exit 1
fi
source ${DIR}/util.sh
source ${DIR}/config.sh $1
set -e
GCLOUD="gcloud"
Header "Creating log persistent disks..."
for i in `seq 0 $((${LOG_NUM_REPLICAS} - 1))`; do
echo "Creating disk ${LOG_DISKS[${i}]}..."
${GCLOUD} compute disks create -q ${LOG_DISKS[${i}]} \
--zone=${LOG_ZONES[${i}]} \
--size=${LOG_DISK_SIZE} &
done
wait
for i in `seq 0 $((${LOG_NUM_REPLICAS} - 1))`; do
echo "Waiting for disk ${LOG_DISKS[${i}]}..."
WaitForStatus disks ${LOG_DISKS[${i}]} ${LOG_ZONES[${i}]} READY &
done
wait
MANIFEST=/tmp/log_container.yaml
Header "Creating log instances..."
for i in `seq 0 $((${LOG_NUM_REPLICAS} - 1))`; do
echo "Creating instance ${LOG_MACHINES[$i]}"
echo "${LOG_META[${i}]}" > ${MANIFEST}.${i}
${GCLOUD} compute instances create -q ${LOG_MACHINES[${i}]} \
--zone=${LOG_ZONES[${i}]} \
--machine-type ${LOG_MACHINE_TYPE} \
--image container-vm \
--disk name=${LOG_DISKS[${i}]},mode=rw,boot=no,auto-delete=yes \
--tags log-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 $((${LOG_NUM_REPLICAS} - 1))`; do
echo "Waiting for instance ${LOG_MACHINES[${i}]}..."
WaitForStatus instances ${LOG_MACHINES[${i}]} ${LOG_ZONES[${i}]} RUNNING &
done
wait
|