X-Git-Url: https://git.decadent.org.uk/gitweb/?p=nfs-utils.git;a=blobdiff_plain;f=debian%2Fnfs-common.init;h=5e30d95998598f800ed10cb16ba46d43c95e84c5;hp=8501601dcfb2e7d4e8caaa74304bc87ae0139fd5;hb=4e01e0a096880cbff37ba542a66838b3115355bc;hpb=6b6945c52f6dbcdb2768e0b43ef3a865fe89b6ba diff --git a/debian/nfs-common.init b/debian/nfs-common.init index 8501601..5e30d95 100644 --- a/debian/nfs-common.init +++ b/debian/nfs-common.init @@ -1,13 +1,16 @@ -#!/bin/sh -# -# nfs-common This shell script takes care of starting and stopping -# common daemons required for NFS clients and servers. -# -# chkconfig: 345 20 80 -# description: NFS is a popular protocol for file sharing across \ -# TCP/IP networks. This service provides NFS file \ -# locking functionality. -# +#!/bin/bash + +### BEGIN INIT INFO +# Provides: nfs-common +# Required-Start: $portmap $time +# Required-Stop: $time +# Default-Start: 2 3 4 5 S +# Default-Stop: 0 1 6 +# Short-Description: NFS support files common to client and server +# Description: NFS is a popular protocol for file sharing across +# TCP/IP networks. This service provides various +# support functions for NFS mounts. +### END INIT INFO # What is this? DESC="NFS common utilities" @@ -15,11 +18,9 @@ DESC="NFS common utilities" # Read config DEFAULTFILE=/etc/default/nfs-common PREFIX= -NEED_LOCKD= +NEED_STATD= NEED_IDMAPD= -IDMAPD_PIDFILE=/var/run/rpc.idmapd.pid NEED_GSSD= -GSSD_PIDFILE=/var/run/rpc.gssd.pid PIPEFS_MOUNTPOINT=/var/lib/nfs/rpc_pipefs RPCGSSDOPTS= if [ -f $DEFAULTFILE ]; then @@ -28,27 +29,8 @@ fi . /lib/lsb/init-functions -# Determine whether lockd daemon is required. -case "$NEED_LOCKD" in -yes|no) ;; -*) case `uname -r` in - '' | [01].* | 2.[0123].* ) - # Older kernels may or may not need a lockd daemon. - # We must assume they do, unless we can prove otherwise. - # (A false positive here results only in a harmless message.) - NEED_LOCKD=yes - if test -f /proc/ksyms - then - grep -q lockdctl /proc/ksyms || NEED_LOCKD=no - fi - ;; - - *) # Modern kernels (>= 2.4) start a lockd thread automatically. - NEED_LOCKD=no - ;; - esac - ;; -esac +# Exit if required binaries are missing. +[ -x $PREFIX/sbin/rpc.statd ] || exit 0 # # Parse the fstab file, and determine whether we need idmapd and gssd. (The @@ -58,21 +40,51 @@ esac AUTO_NEED_IDMAPD=no AUTO_NEED_GSSD=no -exec 9<&0 /dev/null 2>&1 + RET=$? + if [ $RET != 0 ]; then + echo + log_warning_msg "Not starting: portmapper is not running" + exit 0 + fi + fi start-stop-daemon --start --oknodo --quiet \ - --exec $PREFIX/sbin/rpc.lockd - if [ $? != 0 ]; then - log_end_msg $? - exit $? - fi + --pidfile /var/run/rpc.statd.pid \ + --exec $PREFIX/sbin/rpc.statd -- $STATDOPTS + RET=$? + if [ $RET != 0 ]; then + log_end_msg $RET + exit $RET + else + mkdir -p /lib/init/rw/sendsigs.omit.d + rm -f /lib/init/rw/sendsigs.omit.d/statd + ln -s /var/run/rpc.statd.pid /lib/init/rw/sendsigs.omit.d/statd + fi fi + + # Don't start idmapd and gssd if we don't have them (say, if /usr is not + # up yet). + [ -x /usr/sbin/rpc.idmapd ] || NEED_IDMAPD=no + [ -x /usr/sbin/rpc.gssd ] || NEED_GSSD=no + if [ "$NEED_IDMAPD" = yes ] || [ "$NEED_GSSD" = yes ] then + do_modprobe sunrpc do_modprobe nfs - do_modprobe nfs4 + do_modprobe nfsd if do_mount rpc_pipefs $PIPEFS_MOUNTPOINT then if [ "$NEED_IDMAPD" = yes ] then log_progress_msg "idmapd" start-stop-daemon --start --oknodo --quiet \ - --make-pidfile --pidfile $IDMAPD_PIDFILE \ --exec /usr/sbin/rpc.idmapd - if [ $? != 0 ]; then - log_end_msg $? - exit $? + RET=$? + if [ $RET != 0 ]; then + log_end_msg $RET + exit $RET fi fi if [ "$NEED_GSSD" = yes ] then do_modprobe rpcsec_gss_krb5 log_progress_msg "gssd" + + # we need this available; better to fail now than + # mysteriously on the first mount + if ! grep -q -E '^nfs[ ]' /etc/services; then + log_action_end_msg 1 "broken /etc/services, please see /usr/share/doc/nfs-common/README.Debian.nfsv4" + exit 1 + fi + start-stop-daemon --start --oknodo --quiet \ - --make-pidfile --pidfile $GSSD_PIDFILE \ --exec /usr/sbin/rpc.gssd -- $RPCGSSDOPTS - if [ $? != 0 ]; then - log_end_msg $? - exit $? + RET=$? + if [ $RET != 0 ]; then + log_end_msg $RET + exit $RET fi fi fi @@ -186,81 +218,67 @@ case "$1" in log_progress_msg "gssd" start-stop-daemon --stop --oknodo --quiet \ --name rpc.gssd - if [ $? != 0 ]; then - log_end_msg $? - exit $? + RET=$? + if [ $RET != 0 ]; then + log_end_msg $RET + exit $RET fi - rm -f $GSSD_PIDFILE fi if [ "$NEED_IDMAPD" = yes ] then log_progress_msg "idmapd" start-stop-daemon --stop --oknodo --quiet \ --name rpc.idmapd - if [ $? != 0 ]; then - log_end_msg $? - exit $? + RET=$? + if [ $RET != 0 ]; then + log_end_msg $RET + exit $RET fi - rm -f $IDMAPD_PIDFILE fi - if [ "$NEED_LOCKD" = yes ] + if [ "$NEED_STATD" = yes ] then - log_progress_msg "lockd" + log_progress_msg "statd" start-stop-daemon --stop --oknodo --quiet \ - --name rpc.lockd - if [ $? != 0 ]; then - log_end_msg $? - exit $? + --name rpc.statd + RET=$? + if [ $RET != 0 ]; then + log_end_msg $RET + exit $RET fi - else - pkill -KILL -u root -x lockd || true fi - log_progress_msg "statd" - start-stop-daemon --stop --oknodo --quiet \ - --name rpc.statd - if [ $? != 0 ]; then - log_end_msg $? - exit $? - fi do_umount $PIPEFS_MOUNTPOINT 2>/dev/null || true log_end_msg 0 ;; status) - if ! pidof rpc.statd >/dev/null - then - echo "rpc.statd not running" - exit 3 - fi - - if [ "$NEED_GSSD" = yes ] + if [ "$NEED_STATD" = yes ] then - if [ ! -f "$GSSD_PIDFILE" ] || ! pidof rpc.gssd >/dev/null + if ! pidof rpc.statd >/dev/null then - echo "rpc.statd running, but rpc.gssd halted" - exit 3 + echo "rpc.statd not running" + exit 3 fi fi - if [ "$NEED_LOCKD" = yes ] + if [ "$NEED_GSSD" = yes ] then - if ! pidof rpc.lockd >/dev/null + if ! pidof rpc.gssd >/dev/null then - echo "rpc.statd running, but rpc.lockd halted" + echo "rpc.gssd not running" exit 3 fi fi - + if [ "$NEED_IDMAPD" = yes ] then - if [ ! -f "$IDMAPD_PIDFILE" ] || ! pidof rpc.idmapd >/dev/null + if ! pidof rpc.idmapd >/dev/null then - echo "rpc.statd running, but rpc.idmapd halted" + echo "rpc.idmapd not running" exit 3 fi fi - echo "rpc.statd running" + echo "all daemons running" exit 0 ;;