Преглед на файлове

Add script to make sure all nodes are properly running after reboot

multi_domain
ßingen преди 7 години
родител
ревизия
c58a3aa873
променени са 1 файла, в които са добавени 78 реда и са изтрити 0 реда
  1. +78
    -0
      start_on_boot.sh

+ 78
- 0
start_on_boot.sh Целия файл

@@ -0,0 +1,78 @@
#!/bin/bash

STACK_NAME=$1

echo "Processing stack ${STACK_NAME} on reboot"

if [ ! $# -eq 1 ]; then
echo "Usage $0 <stack_name>";
exit 1;
fi

# Script to be run on boot, on crontab
# makes sure that all swarm nodes are ready, so services are split

start_stack() {
echo "Starting stack ${STACK_NAME}"
cd ~/docker_home_server
env $(cat .env | grep "^[A-Z]" | xargs) docker stack deploy --compose-file docker-compose.yml ${STACK_NAME}
}

stop_stack() {
echo "Stopping stack ${STACK_NAME}"
docker stack rm ${STACK_NAME}
sleep 10
docker network ls | grep ${STACK_NAME}_default
if [ $? -gt 0 ]; then
for i in `docker network inspect ${STACK_NAME}_default | grep Name | grep ${STACK_NAME}_ | grep -v ${STACK_NAME}_default | cut -d':' -f2 | cut -d'"' -f 2`; do
echo "Disconnectiong endpoint $i from network ${STACK_NAME}_default";
docker network disconnect -f ${STACK_NAME}_default $i;
done;
fi
sleep 10
}

# is it running?
docker stack ls | grep ${STACK_NAME}
if [ $? -gt 0 ]; then
start_stack
fi

# check workers are up
TMP_FILE="/tmp/pending_nodes.txt"
echo "Checking workers"
for i in $(seq 1 5); do
echo "Attempt 1";
docker node ls --filter role=worker --format "{{.Hostname}} {{.Status}} {{.Availability}}" | grep -v "Ready Active" | tee ${TMP_FILE};
PENDING=`cat ${TMP_FILE} | wc -l`
echo "Pending: ${PENDING}"
if [ $PENDING -eq 0 ]; then
break
fi
sleep 30
done

# check workers have volumes mounted
echo "Checking workers mounted volumes"
echo `docker node ls --filter role=worker --format "{{.Hostname}} {{.Status}} {{.Availability}}" | grep "Ready Active" | cut -f 1 -d ' '`
for node in `docker node ls --filter role=worker --format "{{.Hostname}} {{.Status}} {{.Availability}}" | grep "Ready Active" | cut -f 1 -d ' '`; do
echo "Checking volumes on $node"
ssh $node "mount | grep volumes || mount /media/volumes"
done

# restart stack
stop_stack
start_stack

# wait for OpenLDAP
sleep 120
# add users
# in case it's not ready yet, try 5 times
for i in $(seq 1 5); do
echo "Attempt 1";
./add_users.sh ${STACK_NAME};
if [ $? -eq 0 ]; then
break;
fi
sleep 30
done

Loading…
Отказ
Запис