2009-08-26 10:00:38 -05:00
|
|
|
#!/bin/sh
|
|
|
|
# Start/stop/restart the BIND name server daemon (named).
|
|
|
|
|
2020-02-20 23:40:12 +00:00
|
|
|
# Start BIND. In the past it was more secure to run BIND as a non-root
|
2011-04-25 13:37:00 +00:00
|
|
|
# user (for example, with '-u daemon'), but the modern version of BIND
|
|
|
|
# knows how to use the kernel's capability mechanism to drop all root
|
|
|
|
# privileges except the ability to bind() to a privileged port and set
|
2020-02-18 05:20:50 +00:00
|
|
|
# process resource limits, so running as a non-root user is not needed.
|
|
|
|
# But if you want to run as a non-root user anyway, the command options
|
|
|
|
# can be set like this in /etc/default/named:
|
2011-04-25 13:37:00 +00:00
|
|
|
# NAMED_OPTIONS="-u daemon"
|
|
|
|
# So you will not have to edit this script.
|
2020-02-20 23:40:12 +00:00
|
|
|
#
|
|
|
|
# Please note that if you run BIND as a non-root user, your files in
|
|
|
|
# /var/named may need to be chowned to this user or else named will
|
|
|
|
# refuse to start.
|
2009-08-26 10:00:38 -05:00
|
|
|
|
|
|
|
# You might also consider running BIND in a "chroot jail",
|
|
|
|
# a discussion of which may be found in
|
|
|
|
# /usr/doc/Linux-HOWTOs/Chroot-BIND-HOWTO.
|
|
|
|
|
2020-02-18 05:20:50 +00:00
|
|
|
# One last note: rndc has a lot of other nice features that it is not
|
2011-04-25 13:37:00 +00:00
|
|
|
# within the scope of this start/stop/restart script to support.
|
|
|
|
# For more details, see "man rndc" or just type "rndc" to see the options.
|
2009-08-26 10:00:38 -05:00
|
|
|
|
2011-04-25 13:37:00 +00:00
|
|
|
# Load command defaults:
|
|
|
|
if [ -f /etc/default/named ] ; then . /etc/default/named ; fi
|
|
|
|
if [ -f /etc/default/rndc ] ; then . /etc/default/rndc ; fi
|
2009-08-26 10:00:38 -05:00
|
|
|
|
2020-02-18 05:20:50 +00:00
|
|
|
# Sanity check. If /usr/sbin/named is missing then it
|
2011-04-25 13:37:00 +00:00
|
|
|
# doesn't make much sense to try to run this script:
|
2009-08-26 10:00:38 -05:00
|
|
|
if [ ! -x /usr/sbin/named ]; then
|
|
|
|
echo "/etc/rc.d/rc.bind: no /usr/sbin/named found (or not executable); cannot start."
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2020-02-18 05:20:50 +00:00
|
|
|
# Function to find the user BIND is running as in $NAMED_OPTIONS:
|
|
|
|
find_bind_user() {
|
|
|
|
if echo $NAMED_OPTIONS | grep -wq "\-u" ; then
|
|
|
|
unset BIND_USER USER_FOUND
|
|
|
|
echo $NAMED_OPTIONS | tr ' ' '\n' | while read element ; do
|
|
|
|
if [ "$USER_FOUND" = "true" ]; then
|
|
|
|
BIND_USER="$element"
|
|
|
|
echo $BIND_USER
|
|
|
|
break
|
|
|
|
elif [ "$element" = "-u" ]; then
|
|
|
|
USER_FOUND="true"
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
else
|
|
|
|
echo "root"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
# Start BIND. As many times as you like. ;-)
|
2009-08-26 10:00:38 -05:00
|
|
|
# Seriously, don't run "rc.bind start" if BIND is already
|
|
|
|
# running or you'll get more than one copy running.
|
|
|
|
bind_start() {
|
2020-03-02 19:05:10 +00:00
|
|
|
# Make sure /var/run/named exists:
|
|
|
|
mkdir -p /var/run/named
|
2020-02-18 05:20:50 +00:00
|
|
|
# If we are running as a non-root user, we'll need to be sure that
|
2020-03-02 19:05:10 +00:00
|
|
|
# /var/run/named is chowned properly to that user. Your files in
|
|
|
|
# /var/named may need to be chowned as well, but that will be up to
|
|
|
|
# the sysadmin to do.
|
2020-02-18 05:20:50 +00:00
|
|
|
BIND_USER="$(find_bind_user)"
|
|
|
|
if [ ! "$BIND_USER" = "root" ]; then
|
2020-02-20 23:40:12 +00:00
|
|
|
chown -R $BIND_USER /var/run/named
|
2020-02-18 05:20:50 +00:00
|
|
|
else # prevent error if switching back to running as root:
|
2020-02-20 23:40:12 +00:00
|
|
|
chown -R root /var/run/named
|
2020-02-18 05:20:50 +00:00
|
|
|
fi
|
2020-03-02 19:05:10 +00:00
|
|
|
# Start named:
|
2009-08-26 10:00:38 -05:00
|
|
|
if [ -x /usr/sbin/named ]; then
|
2011-04-25 13:37:00 +00:00
|
|
|
echo "Starting BIND: /usr/sbin/named $NAMED_OPTIONS"
|
|
|
|
/usr/sbin/named $NAMED_OPTIONS
|
2009-08-26 10:00:38 -05:00
|
|
|
sleep 1
|
|
|
|
fi
|
2020-03-02 19:05:10 +00:00
|
|
|
# Make sure that named started:
|
2009-08-26 10:00:38 -05:00
|
|
|
if ! ps axc | grep -q named ; then
|
|
|
|
echo "WARNING: named did not start."
|
2011-04-25 13:37:00 +00:00
|
|
|
echo "Attempting to start named again: /usr/sbin/named $NAMED_OPTIONS"
|
|
|
|
/usr/sbin/named $NAMED_OPTIONS
|
2009-08-26 10:00:38 -05:00
|
|
|
sleep 1
|
|
|
|
if ps axc | grep -q named ; then
|
|
|
|
echo "SUCCESS: named started."
|
|
|
|
else
|
2020-02-18 05:20:50 +00:00
|
|
|
echo "FAILED: Sorry, a second attempt to start named has also failed."
|
|
|
|
echo "There may be a configuration error that needs fixing. Good luck!"
|
2009-08-26 10:00:38 -05:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
# Stop all running copies of BIND (/usr/sbin/named):
|
|
|
|
bind_stop() {
|
2011-04-25 13:37:00 +00:00
|
|
|
echo "Stopping BIND: /usr/sbin/rndc $RDNC_OPTIONS stop"
|
|
|
|
/usr/sbin/rndc $RDNC_OPTIONS stop
|
2009-08-26 10:00:38 -05:00
|
|
|
# A problem with using "/usr/sbin/rndc stop" is that if you
|
|
|
|
# managed to get multiple copies of named running it will
|
|
|
|
# only stop one of them and then can't stop the others even
|
2020-02-18 05:20:50 +00:00
|
|
|
# if you run it again. So, after doing things the nice way
|
|
|
|
# we'll do them the old-fashioned way. If you don't like
|
2009-08-26 10:00:38 -05:00
|
|
|
# it you can comment it out, but unless you have a lot of
|
|
|
|
# other programs you run called "named" this is unlikely
|
|
|
|
# to have any ill effects:
|
|
|
|
sleep 1
|
|
|
|
if ps axc | grep -q named ; then
|
2020-03-02 19:05:10 +00:00
|
|
|
echo "Stopping all named processes in this namespace: /bin/killall --ns \$\$ named"
|
|
|
|
/bin/killall --ns $$ named 2> /dev/null
|
2009-08-26 10:00:38 -05:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
# Reload BIND:
|
|
|
|
bind_reload() {
|
2011-04-25 13:37:00 +00:00
|
|
|
/usr/sbin/rndc $RDNC_OPTIONS reload
|
2009-08-26 10:00:38 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
# Restart BIND:
|
|
|
|
bind_restart() {
|
|
|
|
bind_stop
|
|
|
|
bind_start
|
|
|
|
}
|
|
|
|
|
|
|
|
# Get BIND status:
|
|
|
|
bind_status() {
|
2011-04-25 13:37:00 +00:00
|
|
|
/usr/sbin/rndc $RDNC_OPTIONS status
|
2009-08-26 10:00:38 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
case "$1" in
|
|
|
|
'start')
|
|
|
|
bind_start
|
|
|
|
;;
|
|
|
|
'stop')
|
|
|
|
bind_stop
|
|
|
|
;;
|
|
|
|
'reload')
|
|
|
|
bind_reload
|
|
|
|
;;
|
|
|
|
'restart')
|
|
|
|
bind_restart
|
|
|
|
;;
|
|
|
|
'status')
|
|
|
|
bind_status
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
echo "usage $0 start|stop|reload|restart|status"
|
|
|
|
esac
|