-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdocker-machine-install-bundle.sh
executable file
·111 lines (103 loc) · 2.8 KB
/
docker-machine-install-bundle.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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
#!/usr/bin/env bash
#
# This script installs the bundle to Docker Machine instances, for the purpose
# of testing the latest Docker with Swarm mode enabled.
# Do not use in production.
#
# Requirements (on host to run this script)
# - bash is installed
# - Docker Machine is installed
# - GNU tar is installed
#
# Requirements (on Docker machine instances)
# - Docker can be managed via one of `systemctl`, `service`, or `/etc/init.d/docker`
#
set -e
set -o pipefail
errexit() {
echo "$1"
exit 1
}
BUNDLE="bundles/$(cat VERSION)"
bundle_files(){
# prefer dynbinary if exists
for f in dockerd docker-proxy; do
if [ -d $BUNDLE/dynbinary-daemon ]; then
echo $BUNDLE/dynbinary-daemon/$f
else
echo $BUNDLE/binary-daemon/$f
fi
done
for f in docker-containerd docker-containerd-ctr docker-containerd-shim docker-init docker-runc; do
echo $BUNDLE/binary-daemon/$f
done
if [ -d $BUNDLE/dynbinary-client ]; then
echo $BUNDLE/dynbinary-client/docker
else
echo $BUNDLE/binary-client/docker
fi
}
control_docker(){
m=$1; op=$2
# NOTE: `docker-machine ssh $m sh -c "foo bar"` does not work
# (but `docker-machine ssh $m sh -c "foo\ bar"` works)
# Anyway we avoid using `sh -c` here for avoiding confusion
cat <<EOF | docker-machine ssh $m sudo sh
if command -v systemctl > /dev/null; then
systemctl $op docker
elif command -v service > /dev/null; then
service docker $op
elif [ -x /etc/init.d/docker ]; then
/etc/init.d/docker $op
else
echo "not sure how to control the docker daemon"
exit 1
fi
EOF
}
detect_prefix(){
m=$1
script='dirname $(dirname $(which dockerd))'
echo $script | docker-machine ssh $m sh
}
install_to(){
m=$1; shift; files=$@
echo "$m: detecting docker"
prefix=$(detect_prefix $m)
echo "$m: detected docker on $prefix"
echo "$m: stopping docker"
control_docker $m stop
echo "$m: installing docker"
# NOTE: GNU tar is required because we use --transform here
# TODO: compression (should not be default)
tar ch --transform 's/.*\///' $files | docker-machine ssh $m sudo tar Cx $prefix/bin
echo "$m: starting docker"
control_docker $m start
echo "$m: done"
}
check_prereq(){
command -v docker-machine > /dev/null || errexit "docker-machine not installed"
( tar --version | grep GNU > /dev/null ) || errexit "GNU tar not installed"
}
case "$1" in
"install")
shift; machines=$@
check_prereq
files=$(bundle_files)
echo "Files to be installed:"
for f in $files; do echo $f; done
pids=()
for m in $machines; do
install_to $m $files &
pids+=($!)
done
status=0
for pid in ${pids[@]}; do
wait $pid || { status=$?; echo "background process $pid failed with exit status $status"; }
done
exit $status
;;
*)
errexit "Usage: $0 install MACHINES"
;;
esac