File: trafficserver.init

package info (click to toggle)
trafficserver 9.2.5%2Bds-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 53,008 kB
  • sloc: cpp: 345,484; ansic: 31,134; python: 24,200; sh: 7,271; makefile: 3,045; perl: 2,261; java: 277; pascal: 119; sql: 94; xml: 2
file content (257 lines) | stat: -rw-r--r-- 7,730 bytes parent folder | download | duplicates (2)
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
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
#! /bin/sh

### BEGIN INIT INFO
# Provides:          trafficserver
# Required-Start:    $remote_fs $syslog
# Required-Stop:     $remote_fs $syslog
# Default-Start:     2 3 4 5
# Default-Stop:      0 1 6
# Short-Description: init script for the Apache Traffic Server
# Description:       Apache Traffic Server is fast, scalable and extensible
#                    HTTP/1.1 compliant caching proxy server.
### END INIT INFO

# Author: Arno Töll <debian@toell.net>
#
# This init script is derived from the source package's version shipped
# along the source tarball as rc/trafficserver. Therefore it is a derivative
# work and licensed as follows:
#
#
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements.  See the NOTICE file distributed with
# this work for additional information regarding copyright ownership.
# The ASF licenses this file to You under the Apache License, Version 2.0
# (the "License"); you may not use this file except in compliance with
# the License.  You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

PATH=/sbin:/usr/sbin:/bin:/usr/bin
DESC="Apache Traffic Server"
NAME=trafficserver
SCRIPTNAME=/etc/init.d/$NAME


# Please do not touch TS_ROOT and TS_BASE. Traffic Server uses them
# They are used to determine location of ATS components on the file
# system.
# According to DPM § 9.9 a program must not depend on the existance of
# environment variables to work properly. Please report any errors if
# you experience such a problem, for me it seems to work just fine with-
# out
ESED=/usr/bin/sed
test -x $ESED || ESED=sed
TS_PREFIX="/usr"
TS_ROOT=${TS_ROOT:-$TS_PREFIX}

# TS_BASE is offset inside the file system from where the layout starts
# For standard installations TS_BASE will be empty
eval TS_BASE="`echo $TS_ROOT | ${ESED} -e 's;/usr$;;'`"

# Set some safe defaults. So not change values here, override them in
# in /etc/default/trafficserver instead.
# See there for a documentation as well 

RUNDIR=${RUNDIR:-$TS_BASE/run/trafficserver}

TM_START=${TM_START:-no}
TM_NAME=${TM_NAME:-traffic_manager}
TM_DAEMON=${TM_DAEMON:-$TS_BASE/usr/bin/traffic_manager}
TM_DAEMON_ARGS=""
TM_PIDFILE=${TM_PIDFILE:-$RUNDIR/manager.lock}

TS_START=${TS_START:-no}
TS_NAME=${TS_NAME:-traffic_server}
TS_DAEMON=${TS_DAEMON:-$TS_BASE/usr/bin/traffic_server}
TS_DAEMON_ARGS=""
TS_PIDFILE=${TS_PIDFILE:-$RUNDIR/server.lock}

# Exit if the package is not installed
[ -x "$TM_DAEMON" ] || exit 0


# Read configuration variable file if it is present
[ -r /etc/default/$NAME ] && . /etc/default/$NAME

# Load the VERBOSE setting and other rcS variables
. /lib/init/vars.sh

# Define LSB log_* functions.
. /lib/lsb/init-functions

# Check permissions of /etc/trafficserver.
# Traffic Server needs write permissions, so warn the user if we suppose it
# wouldn't.
# The sysadmin is welcome to change the user ID that ATS uses. However to do that
# in a clean and supported way, the administrator should overwrite the `stat override'
# Debian  installs by default in Trafficserver's postinst maintainer script.
# Print a warning only.
# Since this can't be safely determined by this script print a warning only, but
# don't fail.
CONF_DIR='/etc/trafficserver'
USER=$(dpkg-statoverride --list "$CONF_DIR" | awk '{print $1}')
OWNER=$(env stat -c '%U' "$CONF_DIR")
if [ -d "$CONF_DIR" ] && [ ! "x$OWNER" = "x$USER" ] ; then
	log_warning_msg "Configuration directory '$CONF_DIR' is not owned by user '$USER'. " \
		"However Traffic Server needs write permissions to it."
fi


# Make sure $RUNDIR exists as the underlying file system
# may be volatile (see § 9.3.2 from DPM)
install -d -o trafficserver -g trafficserver -m 0755 "$RUNDIR"


# A helper function, its purpose is to start a daemon.
# Arguments are interpreted in order as follows:
# 1) The executable path
# 2) A string containing optional daemon arguments
# 3) A (valid) path containing the PID file for the daemon
# Returns:
#   0 if daemon has been started
#   1 if daemon was already running
#   2 if daemon could not be started
start_cmd()
{
	# Args
	DAEMON=$1
	DAEMON_ARGS=$2
	PID=$3

	#echo "\n\n"
	#echo "d:" $DAEMON
	#echo "da:" $DAEMON_ARGS
	#echo "pid:" $PID

	start-stop-daemon --start --quiet --pidfile $PID --exec $DAEMON --test > /dev/null \
		|| return 1
	start-stop-daemon --start --quiet --background --pidfile $PID --exec $DAEMON -- \
		$DAEMON_ARGS \
		|| return 2

	return 0
}


# A helper function, its purpose is to stop a daemon.
# Arguments are interpreted in order as follows:
# 1) The daemon name (i.e. the binary name)
# 2) The executable path
# 3) A (valid) path containing the PID file for the daemon
# Returns:
#   0 if daemon has been stopped
#   1 if daemon was already stopped
#   2 if daemon could not be stopped
#   Another value if a failure occurred
stop_cmd()
{
	NAME=$1
	DAEMON=$2
	PID=$3

	start-stop-daemon --stop --quiet --retry=TERM/30/KILL/5 --pidfile $PID --name $NAME
	RETVAL="$?"
	[ "$RETVAL" = 2 ] && return 2

	start-stop-daemon --stop --quiet --oknodo --retry=0/30/KILL/5 --exec $DAEMON
	[ "$?" = 2 ] && return 2

	# Many daemons don't delete their pidfiles when they exit.
	rm -f $PID
	return "$RETVAL"
}

# The start function
# This function does everything required to bring up the service
# at boot time.
# It does not accept any arguments
do_start() {
	if [ "x$TM_START" != "xno" ]; then
                [ "$VERBOSE" != no ] && log_daemon_msg "Starting $TM_NAME"
		start_cmd "$TM_DAEMON" "$TM_DAEMON_ARGS" "$TM_PIDFILE"
		case "$?" in
			0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
			  2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
		esac
	fi

	if [ "x$TS_START" != "xno" ]; then
                [ "$VERBOSE" != no ] && log_daemon_msg "Starting $TS_NAME"
		start_cmd "$TS_DAEMON" "$TS_DAEMON_ARGS" "$TS_PIDFILE"
		case "$?" in
			0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
			  2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
		esac
	fi
}


# The stop function
# This function does everything required to stop the service.
# It does not accept any arguments
do_stop() {
        [ "$VERBOSE" != no ] && log_daemon_msg "Stopping $TM_NAME"
	stop_cmd "$TM_NAME" "$TM_DAEMON" "$TM_PIDFILE"
	case "$?" in
		0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
		2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
	esac

        [ "$VERBOSE" != no ] && log_daemon_msg "Stopping $TS_NAME"
	stop_cmd "$TS_NAME" "$TS_DAEMON" "$TS_PIDFILE"
	case "$?" in
		0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
		2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
	esac
}

case "$1" in
  start)
	if [ "x$TM_START" = "xno" ] && [ "x$TS_START" = "xno" ]; then
		[ "$VERBOSE" != no ] && log_warning_msg "Not starting $DESC"
	else
		do_start
	fi
	;;
  stop)
	do_stop
	;;
  status)
       if [ "x$TM_START" != "xno" ] ; then
               status_of_proc "$TM_DAEMON" "$TM_NAME" -p "$TM_PIDFILE" && exit 0 || exit $?
       else
               status_of_proc "$TS_DAEMON" "$TS_NAME" -p "$TS_PIDFILE" || exit $?
       fi
       ;;
  restart|force-reload)
	log_daemon_msg "Restarting $DESC" "$NAME\n"
	do_stop
	case "$?" in
	  0|1)
		do_start
		case "$?" in
			0) log_end_msg 0 ;;
			1) log_end_msg 1 ;; # Old process is still running
			*) log_end_msg 1 ;; # Failed to start
		esac
		;;
	  *)
	  	# Failed to stop
		log_end_msg 1
		;;
	esac
	;;
  *)
	echo "Usage: $SCRIPTNAME {start|stop|status|restart|force-reload}" >&2
	exit 3
	;;
esac

: