-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathmesos-init-wrapper
executable file
·183 lines (155 loc) · 5.86 KB
/
mesos-init-wrapper
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
173
174
175
176
177
178
179
180
181
182
183
#!/bin/bash
set -o errexit -o nounset -o pipefail
function -h {
cat <<USAGE
USAGE: mesos-init-wrapper (master|agent)
Run Mesos in master or agent mode, loading environment files, setting up
logging and loading config parameters as appropriate.
To configure Mesos, you have many options:
* Set a Zookeeper URL in
/etc/mesos/zk
and it will be picked up by the agent and master.
* You can set environment variables (including the MESOS_* variables) in
files under /etc/default/:
/etc/default/mesos # For both agent and master.
/etc/default/mesos-master # For the master only.
/etc/default/mesos-agent # For the agent only.
* To set command line options for the agent or master, you can create files
under certain directories:
/etc/mesos-agent # For the agent only.
/etc/mesos-master # For the master only.
For example, to set the port for the agent:
echo 5050 > /etc/mesos-agent/port
To set the switch user flag:
touch /etc/mesos-agent/?switch_user
To explicitly disable it:
touch /etc/mesos-agent/?no-switch_user
Adding attributes and resources to the agents is slightly more granular.
Although you can pass them all at once with files called 'attributes' and
'resources', you can also set them by creating files under directories
labeled 'attributes' or 'resources':
echo north-west > /etc/mesos-agent/attributes/rack
This is intended to allow easy addition and removal of attributes and
resources from the agent configuration.
USAGE
}; function --help { -h ;} # A nice way to handle -h and --help
export LC_ALL=en_US.UTF-8 # A locale that works consistently
function main {
err "Please use \`master' or \`agent'."
}
# Search supplied directory for files that do not end with .dkpg-dist or .rpmnew
function find_files {
find "$1" -maxdepth 1 -name '*.dpkg-dist' -o -name '*.rpmnew' -prune \
-o \( -type f -print \)
}
function agent {
local etc_agent=/etc/mesos-agent
local args=()
local attributes=()
local resources=()
# Call mesosphere-dnsconfig if present on the system to generate config files.
[ -x /usr/bin/mesosphere-dnsconfig ] && mesosphere-dnsconfig -write -service=mesos-agent
set -o allexport
[[ ! -f /etc/default/mesos ]] || . /etc/default/mesos
[[ ! -f /etc/default/mesos-agent ]] || . /etc/default/mesos-agent
set +o allexport
[[ ! ${ULIMIT:-} ]] || ulimit $ULIMIT
[[ ! ${MASTER:-} ]] || args+=( --master="$MASTER" )
[[ ! ${IP:-} ]] || args+=( --ip="$IP" )
[[ ! ${LOGS:-} ]] || args+=( --log_dir="$LOGS" )
[[ ! ${ISOLATION:-} ]] || args+=( --isolation="$ISOLATION" )
for f in $(find_files "$etc_agent") # attributes ip resources isolation &al.
do
if [[ -f $f ]]
then
local name="$(basename "$f")"
if [[ $name == '?'* ]] # Recognize flags (options without values)
then args+=( --"${name#'?'}" )
else args+=( --"$name"="$(cat "$f")" )
fi
fi
done
# We allow the great multitude of attributes and resources to be specified
# in directories, where the filename is the key and the contents its value.
for f in $(find_files "$etc_agent"/attributes/)
do [[ ! -s $f ]] || attributes+=( "$(basename "$f")":"$(cat "$f")" )
done
if [[ ${#attributes[@]} -gt 0 ]]
then
local formatted="$(printf ';%s' "${attributes[@]}")"
args+=( --attributes="${formatted:1}" ) # NB: Leading ';' is clipped
fi
for f in $(find_files "$etc_agent"/resources/)
do [[ ! -s $f ]] || resources+=( "$(basename "$f")":"$(cat "$f")" )
done
if [[ ${#resources[@]} -gt 0 ]]
then
local formatted="$(printf ';%s' "${resources[@]}")"
args+=( --resources="${formatted:1}" ) # NB: Leading ';' is clipped
fi
if [[ "${args[@]:-}" == *'--no-logger'* ]]
then
local clean_args=()
for i in "${args[@]}"; do
if [[ "${i}" != "--no-logger" ]]; then
clean_args+=( "${i}" )
fi
done
exec /usr/sbin/mesos-agent "${clean_args[@]}"
else
logged /usr/sbin/mesos-agent "${args[@]:-}"
fi
}
function master {
local etc_master=/etc/mesos-master
local args=()
# Call mesosphere-dnsconfig if present on the system to generate config files.
[ -x /usr/bin/mesosphere-dnsconfig ] && mesosphere-dnsconfig -write -service=mesos-master
set -o allexport
[[ ! -f /etc/default/mesos ]] || . /etc/default/mesos
[[ ! -f /etc/default/mesos-master ]] || . /etc/default/mesos-master
set +o allexport
[[ ! ${ULIMIT:-} ]] || ulimit $ULIMIT
[[ ! ${ZK:-} ]] || args+=( --zk="$ZK" )
[[ ! ${IP:-} ]] || args+=( --ip="$IP" )
[[ ! ${PORT:-} ]] || args+=( --port="$PORT" )
[[ ! ${CLUSTER:-} ]] || args+=( --cluster="$CLUSTER" )
[[ ! ${LOGS:-} ]] || args+=( --log_dir="$LOGS" )
for f in $(find_files "$etc_master") # cluster log_dir port &al.
do
if [[ -f $f ]]
then
local name="$(basename "$f")"
if [[ $name == '?'* ]] # Recognize flags (options without values)
then args+=( --"${name#'?'}" )
else args+=( --"$name"="$(cat "$f")" )
fi
fi
done
if [[ "${args[@]:-}" == *'--no-logger'* ]]
then
local clean_args=()
for i in "${args[@]}"; do
if [[ "${i}" != "--no-logger" ]]; then
clean_args+=( "${i}" )
fi
done
exec /usr/sbin/mesos-master "${clean_args[@]}"
else
logged /usr/sbin/mesos-master "${args[@]:-}"
fi
}
# Send all output to syslog and tag with PID and executable basename.
function logged {
local tag="${1##*/}[$$]"
exec 1> >(exec logger -p user.info -t "$tag")
exec 2> >(exec logger -p user.err -t "$tag")
exec "$@"
}
function msg { out "$*" >&2 ;}
function err { local x=$? ; msg "$*" ; return $(( $x == 0 ? 1 : $x )) ;}
function out { printf '%s\n' "$*" ;}
if [[ ${1:-} ]] && declare -F | cut -d' ' -f3 | fgrep -qx -- "${1:-}"
then "$@"
else main "$@"
fi