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
|
#!/bin/sh
### BEGIN INIT INFO
# Provides: knot
# Required-Start: $network $local_fs $remote_fs $syslog
# Required-Stop: $remote_fs $syslog
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: authoritative domain name server
# Description: Knot DNS is a authoritative-only domain name server
### END INIT INFO
# Author: Ondřej Surý <ondrej@debian.org>
# PATH should only include /usr/* if it runs after the mountnfs.sh script
PATH=/sbin:/usr/sbin:/bin:/usr/bin
DESC="Knot DNS server" # Introduce a short description here
NAME=knotd # Introduce the short server's name here
DAEMON=/usr/sbin/$NAME # Introduce the server's location here
PIDFILE=/run/knot/knot.pid
SCRIPTNAME=/etc/init.d/knot
KNOTC=/usr/sbin/knotc
RUNDIR=/run/knot
# Exit if the package is not installed
[ -x $DAEMON ] || exit 0
KNOTD_ARGS=""
# Read configuration variable file if it is present
[ -r /etc/default/knot ] && . /etc/default/knot
DAEMON_ARGS="-d $KNOTD_ARGS"
# Define LSB log_* functions.
# Depend on sysvinit-utils (>= 2.96) to ensure that this file is present.
. /lib/lsb/init-functions
#
# Function that starts the daemon/service
#
do_start()
{
# Return
# 0 if daemon has been started
# 1 if daemon was already running
# 2 if daemon could not be started
$KNOTC status >/dev/null 2>/dev/null \
&& return 1
start-stop-daemon --start --quiet --pidfile $PIDFILE --exec $DAEMON --test > /dev/null \
|| return 1
start-stop-daemon --start --quiet --pidfile $PIDFILE --exec $DAEMON -- \
$DAEMON_ARGS \
|| return 2
}
#
# Function that stops the daemon/service
#
do_stop()
{
# Return
# 0 if daemon has been stopped
# 1 if daemon was already stopped
# 2 if daemon could not be stopped
# other if a failure occurred
$KNOTC status >/dev/null 2>/dev/null \
|| return 1
$KNOTC stop >/dev/null
RETVAL="$?"
[ $? = 1 ] && return 2
# Many daemons don't delete their pidfiles when they exit.
rm -f $PIDFILE
return 0
}
do_reload() {
$KNOTC reload >/dev/null
return $?
}
do_mkrundir() {
mkdir -p $RUNDIR
chmod 0755 $RUNDIR
chown knot:knot $RUNDIR
}
case "$1" in
start)
do_mkrundir
log_daemon_msg "Starting $DESC " "$NAME"
do_start
case "$?" in
0|1) log_end_msg 0 ;;
2) log_end_msg 1 ;;
esac
;;
stop)
log_daemon_msg "Stopping $DESC" "$NAME"
do_stop
case "$?" in
0|1) log_end_msg 0 ;;
2) log_end_msg 1 ;;
esac
;;
status)
STATUS=$($KNOTC status 2>&1 >/dev/null)
RETVAL=$?
if [ $RETVAL = 0 ]; then
log_success_msg "$NAME is running"
else
log_failure_msg "$NAME is not running ($STATUS)"
fi
exit $RETVAL
;;
reload|force-reload)
log_daemon_msg "Reloading $DESC" "$NAME"
do_reload
log_end_msg $?
;;
restart)
log_daemon_msg "Restarting $DESC" "$NAME"
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|reload|force-reload}" >&2
exit 3
;;
esac
:
|