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 prometheus persistent disks..."
for i in `seq 0 $((${PROMETHEUS_NUM_REPLICAS} - 1))`; do
echo "Creating disk ${PROMETHEUS_DISKS[${i}]}..."
${GCLOUD} compute disks create -q ${PROMETHEUS_DISKS[${i}]} \
--zone=${PROMETHEUS_ZONES[${i}]} \
--size=${PROMETHEUS_DISK_SIZE} &
done
wait
for i in `seq 0 $((${PROMETHEUS_NUM_REPLICAS} - 1))`; do
echo "Waiting for disk ${PROMETHEUS_DISKS[${i}]}..."
WaitForStatus disks ${PROMETHEUS_DISKS[${i}]} ${PROMETHEUS_ZONES[${i}]} READY &
done
wait
MANIFEST=/tmp/prometheus_container.yaml
sed --e "s^@@PROJECT@@^${PROJECT}^" \
< ${DIR}/prometheus_container.yaml > ${MANIFEST}
Header "Creating prometheus instances..."
for i in `seq 0 $((${PROMETHEUS_NUM_REPLICAS} - 1))`; do
echo "Creating instance ${PROMETHEUS_MACHINES[$i]}"
${GCLOUD} compute instances create -q ${PROMETHEUS_MACHINES[${i}]} \
--zone=${PROMETHEUS_ZONES[${i}]} \
--machine-type ${PROMETHEUS_MACHINE_TYPE} \
--image container-vm \
--disk name=${PROMETHEUS_DISKS[${i}]},mode=rw,boot=no,auto-delete=yes \
--tags prometheus-node \
--metadata-from-file startup-script=${DIR}/node_init.sh,google-container-manifest=${MANIFEST} &
done
wait
for i in `seq 0 $((${PROMETHEUS_NUM_REPLICAS} - 1))`; do
echo "Waiting for instance ${PROMETHEUS_MACHINES[${i}]}..."
WaitForStatus instances ${PROMETHEUS_MACHINES[${i}]} ${PROMETHEUS_ZONES[${i}]} RUNNING &
done
wait
|