-
Notifications
You must be signed in to change notification settings - Fork 57
/
Copy pathmarathon-service-discovery.sh
executable file
·91 lines (81 loc) · 3.67 KB
/
marathon-service-discovery.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
#!/bin/sh
#/*
# * Copyright (c) 2012 Adobe Systems Incorporated. All rights reserved.
# *
# * Permission is hereby granted, free of charge, to any person obtaining a
# * copy of this software and associated documentation files (the "Software"),
# * to deal in the Software without restriction, including without limitation
# * the rights to use, copy, modify, merge, publish, distribute, sublicense,
# * and/or sell copies of the Software, and to permit persons to whom the
# * Software is furnished to do so, subject to the following conditions:
# *
# * The above copyright notice and this permission notice shall be included in
# * all copies or substantial portions of the Software.
# *
# * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
# * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
# * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
# * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
# * DEALINGS IN THE SOFTWARE.
# *
# */
#
# Overview:
# It reads the list of tasks from Marathon and it dynamically generates the Nginx configuration with the upstreams.
#
# In order to gather the information the script needs to know where to find Marathon
# so it looks for the $MARATHON_HOST environment variable.
#
TMP_FILE=/tmp/api-gateway-upstreams.http.conf
UPSTREAM_FILE=/etc/api-gateway/environment.conf.d/api-gateway-upstreams.http.conf
marathon_host=$(echo $MARATHON_HOST)
do_log() {
local _MSG=$1
echo "`date +'%Y/%m/%d %H:%M:%S'` - marathon-service-discovery: ${_MSG}"
}
error_log() {
local _MSG=$1
do_log "ERROR: ${_MSG}"
}
fatal_error() {
local _MSG=$1
error_log "${_MSG}"
exit 255
}
info_log() {
local _MSG=$1
do_log "${_MSG}"
}
# 0. Obtain list of current tasks from Marathon. If not available, skip reload
existing_tasks=$(curl -s ${marathon_host}/v2/tasks -H "Accept:text/plain")
found_existing_tasks=$?
if [ ${found_existing_tasks} -eq 0 ]; then
# 1. create the new upstream config
# NOTE: for the moment when tasks expose multiple ports, only the first one is exposed through nginx
echo "$existing_tasks" | awk 'NF>2' | grep -v :0 | awk '!seen[$1]++' | awk ' {s=""; for (f=3; f<=NF; f++) s = s "\n server " $f " fail_timeout=10s;" ; print "upstream " $1 " {" s "\n keepalive 16;\n}" }' > ${TMP_FILE}
# 1.1. check redis upstreams
#
# ASSUMPTION: there is a redis app named "api-gateway-redis" deployed in marathon and optionally another app named "api-gateway-redis-replica"
#
redis_master=$(cat ${TMP_FILE} | grep api-gateway-redis | wc -l)
redis_replica=$(cat ${TMP_FILE} | grep api-gateway-redis-replica | wc -l)
# if api-gateway-redis upstream exists but api-gateway-redis-replica does not, then create the replica
if [ ${redis_master} -gt 0 ] && [ ${redis_replica} -eq 0 ]; then
# clone api-gateway-redis block
sed -e '/api-gateway-redis/,/}/!d' ${TMP_FILE} | sed 's/-redis/-redis-replica/' >> ${TMP_FILE}
fi
if [ ${redis_master} -eq 0 ]; then
echo "upstream api-gateway-redis { server 127.0.0.1:6379; }" >> ${TMP_FILE}
fi
# 2 check for changes
cmp -s ${TMP_FILE} ${UPSTREAM_FILE}
changed_upstreams=$?
if [[ \( ${changed_upstreams} -gt 0 \) ]]; then
info_log "Copying new upstreams config into place"
cp ${TMP_FILE} ${UPSTREAM_FILE}
fi
else
error_log "Unable to find existing marathon tasks: curl error code '${found_existing_tasks}', skipping upstream reload"
fi