-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathshutdown-cluster.sh
executable file
·53 lines (41 loc) · 1.6 KB
/
shutdown-cluster.sh
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
#!/bin/bash
set -eux
exec 1> >(logger -s -t $(basename $0)) 2>&1
for host in `sudo docker node ls --filter "role=manager" --format="{{.Hostname}}"`
do
echo "Draining node: $host"
CMD_OUTPUT=`sudo docker node update --availability drain $host`
echo "CMD_OUTPUT=$CMD_OUTPUT"
done
echo "Drained Manager Nodes...waiting 30 seconds to stabilize...."
sleep 30
for host in `sudo docker node ls --filter "role=worker" --format="{{.Hostname}}"`
do
echo "Draining node: $host"
CMD_OUTPUT=`sudo docker node update --availability drain $host`
echo "CMD_OUTPUT=$CMD_OUTPUT"
done
echo "Drained Worker Nodes...waiting 30 seconds to stabilize...."
sleep 30
echo "remove stateful docker stacks [mon & elk] to allow graceful cluster rejoin upon reboot"
CMD_OUTPUT=`sudo docker stack rm elk`
echo "Removed elk stack, CMD_OUTPUT=$CMD_OUTPUT"
CMD_OUTPUT=`sudo docker stack rm mon`
echo "Removed mon stack, CMD_OUTPUT=$CMD_OUTPUT"
## TODO: Need consistent user login name (ubuntu vs pi)
# echo "Shutting down worker nodes"
# for host in `sudo docker node ls --filter "role=worker" --format="{{.Hostname}}"`
# do
# echo "shutting down node: $node"
# CMD_OUTPUT=`sudo shut`
# echo "CMD_OUTPUT=$CMD_OUTPUT"
# done
#TODO These need to be IPs, DNS is dead at this point
echo "Shutting down worker nodes"
ssh pi@raspberrypi-beta sudo shutdown now
ssh pi@raspberrypi-delta-3 sudo shutdown now
ssh ubuntu@raspberrypi-delta-5 sudo shutdown now
ssh pi@raspberrypicharlie sudo shutdown now
echo "Shutting down manager nodes"
ssh ubuntu@raspberrypi-delta-2 sudo shutdown now
ssh ubuntu@raspberrypi-delta-4 sudo shutdown now