X-Git-Url: https://git.decadent.org.uk/gitweb/?p=nfs-utils.git;a=blobdiff_plain;f=debian%2Fnfs-common.init;h=25ff4f757c7314544a122eb1c0e06638dc19f863;hp=dc93bea0846a3a13f080b793259339b26982ab19;hb=97820a9040bdfe3bccdbfc58b1df88883bba0abe;hpb=10cfddc260b77025807906f72c8d98d9fe84a6c5 diff --git a/debian/nfs-common.init b/debian/nfs-common.init index dc93bea..25ff4f7 100644 --- a/debian/nfs-common.init +++ b/debian/nfs-common.init @@ -1,4 +1,4 @@ -#!/bin/sh +#!/bin/bash ### BEGIN INIT INFO # Provides: nfs-common @@ -17,11 +17,9 @@ DESC="NFS common utilities" # Read config DEFAULTFILE=/etc/default/nfs-common -PREFIX= NEED_STATD= -NEED_IDMAPD= NEED_GSSD= -PIPEFS_MOUNTPOINT=/var/lib/nfs/rpc_pipefs +PIPEFS_MOUNTPOINT=/run/rpc_pipefs RPCGSSDOPTS= if [ -f $DEFAULTFILE ]; then . $DEFAULTFILE @@ -30,14 +28,13 @@ fi . /lib/lsb/init-functions # Exit if required binaries are missing. -[ -x $PREFIX/sbin/rpc.statd ] || exit 0 +[ -x /sbin/rpc.statd ] || exit 0 # -# Parse the fstab file, and determine whether we need idmapd and gssd. (The +# Parse the fstab file, and determine whether we need gssd. (The # /etc/defaults settings, if any, will override our autodetection.) This code # is partially adapted from the mountnfs.sh script in the sysvinit package. # -AUTO_NEED_IDMAPD=no AUTO_NEED_GSSD=no if [ -f /etc/fstab ]; then @@ -45,9 +42,11 @@ if [ -f /etc/fstab ]; then while read DEV MTPT FSTYPE OPTS REST do - if [ "$FSTYPE" = "nfs4" ]; then - AUTO_NEED_IDMAPD=yes - fi + case $DEV in + ''|\#*) + continue + ;; + esac case "$OPTS" in sec=krb5|*,sec=krb5|sec=krb5,*|*,sec=krb5i,*|sec=krb5i|*,sec=krb5i|sec=krb5i,*|*,sec=krb5i,*|sec=krb5p|*,sec=krb5p|sec=krb5p,*|*,sec=krb5p,*) @@ -59,19 +58,6 @@ if [ -f /etc/fstab ]; then exec 0<&9 9<&- fi -# -# We also need idmapd if we run an NFSv4 server. It's fairly difficult -# to autodetect whether there are NFSv4 exports or not, and idmapd is not a -# particularily heavy daemon, so we auto-enable it if we find an /etc/exports -# file. This does not mean that there are NFSv4 or other mounts active (or -# even that nfs-kernel-server is installed), but it matches what the "start" -# condition in nfs-kernel-server's init script does, which has a value in -# itself. -# -if [ -f /etc/exports ] && grep -q '^[[:space:]]*[^#]*/' /etc/exports; then - AUTO_NEED_IDMAPD=yes -fi - case "$NEED_STATD" in yes|no) ;; @@ -84,7 +70,7 @@ case "$NEED_IDMAPD" in yes|no) ;; *) - NEED_IDMAPD=$AUTO_NEED_IDMAPD + NEED_IDMAPD=yes ;; esac @@ -131,12 +117,29 @@ case "$1" in if [ "$NEED_STATD" = yes ]; then log_progress_msg "statd" + + # See if rpcbind is running + if [ -x /usr/sbin/rpcinfo ]; then + /usr/sbin/rpcinfo -p >/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.statd -- $STATDOPTS + --pidfile /var/run/rpc.statd.pid \ + --exec /sbin/rpc.statd -- $STATDOPTS RET=$? if [ $RET != 0 ]; then log_end_msg $RET exit $RET + else + if [ -d /run/sendsigs.omit.d ]; then + rm -f /run/sendsigs.omit.d/statd + ln -s /var/run/rpc.statd.pid /run/sendsigs.omit.d/statd + fi fi fi @@ -150,6 +153,7 @@ case "$1" in do_modprobe sunrpc do_modprobe nfs do_modprobe nfsd + mkdir -p "$PIPEFS_MOUNTPOINT" if do_mount rpc_pipefs $PIPEFS_MOUNTPOINT then if [ "$NEED_IDMAPD" = yes ]