Переглянути джерело

REmove outdated swarm start script

master
Bingen Eguzkitza 5 роки тому
джерело
коміт
e446f1f54c
1 змінених файлів з 0 додано та 78 видалено
  1. +0
    -78
      start_on_boot.sh

+ 0
- 78
start_on_boot.sh Переглянути файл

@@ -1,78 +0,0 @@
#!/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}.local "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 "Adding users - Attempt $i";
./add_users.sh ${STACK_NAME};
if [ $? -eq 0 ]; then
break;
fi
sleep 30
done

Завантаження…
Відмінити
Зберегти