-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathdocker-auto.sh
executable file
·172 lines (149 loc) · 4.7 KB
/
docker-auto.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
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
#!/usr/bin/env bash
set -e
SCRIPT_BASE_PATH=$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )
cd "$SCRIPT_BASE_PATH"
###############################################
# Extract Environment Variables from .env file
# Ex. REGISTRY_URL="$(getenv REGISTRY_URL)"
###############################################
getenv(){
local _env="$(printenv $1)"
echo "${_env:-$(cat .env | awk 'BEGIN { FS="="; } /^'$1'/ {sub(/\r/,"",$2); print $2;}')}"
}
DOCKER_COMPOSE_VERSION="1.14.0"
CONF_ARG="-f docker-compose-prod-elk.yml"
PATH=$PATH:/usr/local/bin/
REGISTRY_URL="$(getenv REGISTRY_URL)"
########################################
# Install docker-compose
# DOCKER_COMPOSE_VERSION need to be set
########################################
install_docker_compose() {
sudo curl -L "https://github.com/docker/compose/releases/download/$DOCKER_COMPOSE_VERSION/docker-compose-$(uname -s)-$(uname -m)" \
-o /usr/local/bin/docker-compose
sudo chmod +x /usr/local/bin/docker-compose
return 0
}
if ! command -v docker-compose >/dev/null 2>&1; then
install_docker_compose || true
elif [[ "$(docker-compose version --short)" != "$DOCKER_COMPOSE_VERSION" ]]; then
install_docker_compose || true
fi
usage() {
echo "Usage: $(basename "$0") [MODE] [OPTIONS] [COMMAND]"
echo
echo "Mode:"
echo " --prod ELK Stack for production"
echo " --dev ELK Stack for development"
echo
echo "Options:"
echo " --with-cadv Add CAdvisor service"
echo " --with-hub Add encrypted connection for Kibana, hub required"
echo " --with-tls Add TLS connection to ES/LS (certificates required)"
echo " --with-notls Normal TCP connection (no certificates)"
echo
echo "Commands:"
echo " up Start the services"
echo " down Stop the services"
echo " ps Show the status of the services"
echo " logs Follow the logs on console"
echo " login Log in to a Docker registry"
echo " remove-all Remove all containers"
echo " stop-all Stop all containers running"
echo " backup Create a snapshot of the entire cluster"
echo " delete-old Remove indices older than # days, see curator action for more details"
echo
}
if [ $# -eq 0 ]; then
usage
exit 1
fi
WITH_TLS=false
WITH_NOTLS=false
for i in "$@"
do
case $i in
--prod)
CONF_ARG="-f docker-compose-prod-elk.yml"
shift
;;
--dev)
CONF_ARG="-f docker-compose-dev-elk.yml"
shift
;;
--with-tls)
CONF_ARG="$CONF_ARG -f docker-compose-with-tls.yml"
WITH_TLS=true
shift
;;
--with-notls)
CONF_ARG="$CONF_ARG -f docker-compose-with-notls.yml"
WITH_NOTLS=true
shift
;;
--with-cadv)
CONF_ARG="$CONF_ARG -f docker-compose-cadvisor.yml"
shift
;;
--with-hub)
CONF_ARG="$CONF_ARG -f docker-compose-with-hub.yml"
shift
;;
--help|-h)
usage
exit 1
;;
*)
break
;;
esac
done
if $WITH_TLS && $WITH_NOTLS; then
echo "You don't want to call it with both tls and notls option..."
usage
exit 1
elif ! $WITH_TLS && ! $WITH_NOTLS; then
echo "Default to no tls (no encryption!)."
CONF_ARG="$CONF_ARG -f docker-compose-with-notls.yml"
WITH_NOTLS=true
fi
echo "Arguments: $CONF_ARG"
echo "Command: $@"
if [ "$1" == "login" ]; then
docker login $REGISTRY_URL
exit 0
elif [ "$1" == "up" ]; then
docker-compose $CONF_ARG pull
docker-compose $CONF_ARG build --pull
docker-compose $CONF_ARG up -d --remove-orphans
exit 0
elif [ "$1" == "stop-all" ]; then
if [ -n "$(docker ps --format {{.ID}})" ]
then docker stop $(docker ps --format {{.ID}}); fi
exit 0
elif [ "$1" == "remove-all" ]; then
if [ -n "$(docker ps -a --format {{.ID}})" ]
then docker rm $(docker ps -a --format {{.ID}}); fi
exit 0
elif [ "$1" == "logs" ]; then
shift
docker-compose $CONF_ARG logs -f --tail 200 "$@"
exit 0
elif [ "$1" == "backup" ]; then
docker-compose $CONF_ARG pull
docker-compose $CONF_ARG build --pull
docker-compose $CONF_ARG -f docker-compose-curator.yml run curator create-snapshot.yml
docker-compose $CONF_ARG -f docker-compose-curator.yml run curator delete-old-snapshots.yml
exit 0
elif [ "$1" == "delete-old" ]; then
docker-compose $CONF_ARG pull
docker-compose $CONF_ARG build --pull
docker-compose $CONF_ARG -f docker-compose-curator.yml run curator delete-old-indices.yml
exit 0
elif [ "$1" == "restore" ]; then
docker-compose $CONF_ARG pull
docker-compose $CONF_ARG build --pull
docker-compose $CONF_ARG -f docker-compose-curator.yml run curator restore-snapshot.yml
exit 0
fi
docker-compose $CONF_ARG "$@"