#!/bin/bash # # named This shell script takes care of starting and stopping # named (BIND DNS server). # # chkconfig: - 13 87 # description: named (BIND) is a Domain Name Server (DNS) \ # that is used to resolve host names to IP addresses. # probe: true ### BEGIN INIT INFO # Provides: $named # Required-Start: $local_fs $network $syslog # Required-Stop: $local_fs $network $syslog # Default-Start: # Default-Stop: 0 1 2 3 4 5 6 # Short-Description: start|stop|status|restart|try-restart|reload|force-reload DNS server # Description: control ISC BIND implementation of DNS server ### END INIT INFO # Source function library. . /etc/rc.d/init.d/functions ROOTDIR="/data/named" OPTIONS="-u named -4 -c /etc/named.conf" RETVAL=0 named='named' # Don't kill named during clean-up NAMED_SHUTDOWN_TIMEOUT=${NAMED_SHUTDOWN_TIMEOUT:-25} if [ -n "$ROOTDIR" ]; then ROOTDIR=`echo $ROOTDIR | sed 's#//*#/#g;s#/$##'`; rdl=`/usr/bin/readlink $ROOTDIR`; if [ -n "$rdl" ]; then ROOTDIR="$rdl"; fi; fi PIDFILE="/var/run/named/named.pid" ROOTDIR_MOUNT='/etc/named /etc/pki/dnssec-keys /var/named /etc/named.conf /etc/named.dnssec.keys /etc/named.rfc1912.zones /etc/rndc.conf /etc/rndc.key /usr/lib64/bind /usr/lib/bind /etc/named.iscdlv.key /etc/named.root.key' pidofnamed() { pidofproc -p "$ROOTDIR/$PIDFILE" "$named"; } # Check if all what named needs running start() { [ "$EUID" != "0" ] && exit 4 # Source networking configuration. [ -r /etc/sysconfig/network ] && . /etc/sysconfig/network # Check that networking is up [ "${NETWORKING}" = "no" ] && exit 1 [ -x /data/bind98/sbin/"$named" ] || exit 5 # Handle -c option previous_option='unspecified'; for a in $OPTIONS; do if [ $previous_option = '-c' ]; then named_conf=$a; fi; previous_option=$a; done; named_conf=${named_conf:-/etc/named.conf}; if [ ! -r $ROOTDIR$named_conf ]; then echo 'Cannot find configuration file. You could create it by system-config-bind' exit 6; fi; [ -x /sbin/portrelease ] && /sbin/portrelease named &>/dev/null || : # all pre-start is done, lets start named echo -n $"Starting named: " if [ -n "`pidofnamed`" ]; then echo -n $"named: already running" success echo exit 0; fi; if ! [ "$DISABLE_ZONE_CHECKING" = yes ]; then ckcf_options='-z'; # enable named-checkzone for each zone (9.3.1+) ! fi; if [ -n "${ROOTDIR}" -a "x${ROOTDIR}" != "x/" ]; then OPTIONS="${OPTIONS} -t ${ROOTDIR}" ckcf_options="$ckcf_options -t ${ROOTDIR}"; [ -s /etc/localtime ] && cp -fp /etc/localtime ${ROOTDIR}/etc/localtime; fi RETVAL=0 # check if configuration is correct if [ -x /data/bind98/sbin/named-checkconf ] && [ -x /data/bind98/sbin/named-checkzone ] && /data/bind98/sbin/named-checkconf $ckcf_options ${named_conf} >/dev/null 2>&1; then daemon --pidfile "$ROOTDIR/$PIDFILE" /data/bind98/sbin/"$named" -u named ${OPTIONS}; RETVAL=$? if [ $RETVAL -eq 0 ]; then rm -f /var/run/{named,named-sdb}.pid; ln -s $ROOTDIR/"$PIDFILE" /var/run/"$named".pid; fi; else named_err="`/data/bind98/sbin/named-checkconf $ckcf_options $named_conf 2>&1`"; echo echo "Error in named configuration:"; echo "$named_err"; failure echo [ -x /usr/bin/logger ] && echo "$named_err" | /usr/bin/logger -pdaemon.error -tnamed; exit 2; fi; echo if [ $RETVAL -eq 0 ]; then touch /var/lock/subsys/named; else exit 7; fi return 0; } stop() { [ "$EUID" != "0" ] && exit 4 # Stop daemons. echo -n $"Stopping named: " [ -x /data/bind98/sbin/rndc ] && /data/bind98/sbin/rndc stop >/dev/null 2>&1; RETVAL=$? # was rndc successful? [ "$RETVAL" -eq 0 ] || \ killproc -p "$ROOTDIR/$PIDFILE" "$named" -TERM >/dev/null 2>&1 timeout=0 RETVAL=0 while pidofnamed &>/dev/null; do if [ $timeout -ge $NAMED_SHUTDOWN_TIMEOUT ]; then RETVAL=1 break else sleep 2 && echo -n "." timeout=$((timeout+2)) fi; done # remove pid files if [ $RETVAL -eq 0 ]; then rm -f /var/lock/subsys/named rm -f /var/run/{named,named-sdb}.pid fi; if [ $RETVAL -eq 0 ]; then success else failure RETVAL=1 fi; echo return $RETVAL } rhstatus() { [ -x /data/bind98/sbin/rndc ] && /data/bind98/sbin/rndc status; status -p "$ROOTDIR/$PIDFILE" -l named /data/bind98/sbin/"$named"; return $? } restart() { stop start } reload() { [ "$EUID" != "0" ] && exit echo -n $"Reloading "$named": " p=`pidofnamed` RETVAL=$? if [ "$RETVAL" -eq 0 ]; then /data/bind98/sbin/rndc reload >/dev/null 2>&1 || /bin/kill -HUP $p; RETVAL=$? fi [ "$RETVAL" -eq 0 ] && success $"$named reload" || failure $"$named reload" echo return $RETVAL } checkconfig() { ckcf_options='-z'; if [ -n "${ROOTDIR}" -a "x${ROOTDIR}" != "x/" ]; then ckcf_options="$ckcf_options -t ${ROOTDIR}"; fi; if [ -x /data/bind98/sbin/named-checkconf ] && [ -x /data/bind98/sbin/named-checkzone ] && /data/bind98/sbin/named-checkconf $ckcf_options ${named_conf} ; then return 0; else return 1; fi } # See how we were called. case "$1" in start) start ;; stop) stop ;; status) rhstatus; RETVAL=$? ;; restart) restart ;; condrestart|try-restart) if [ -e /var/lock/subsys/named ]; then restart; fi ;; reload) reload ;; force-reload) if ! reload; then restart; fi ;; checkconfig|configtest|check|test) checkconfig ;; *) echo $"Usage: $0 {start|stop|status|restart|try-restart|reload|force-reload}" [ "x$1" = "x" ] && exit 0 exit 2 esac /bin/date "+%Y%m%d %H:%M:%S" >> /data/logs/bind/named.log echo "$1 $RETVAL" >> /data/logs/bind/named.log exit $RETVAL