]> git.pld-linux.org Git - packages/nfs-utils.git/blobdiff - nfsfs.init
- rel 11
[packages/nfs-utils.git] / nfsfs.init
index d25609165c518bcd27d5fbe5cf9890f593f6441b..d765d5b909ae38ec6d50e8d5cf9152625476662e 100644 (file)
@@ -35,31 +35,26 @@ if [ "$1" != "stop" ]; then
        check_portmapper || { nls "Error: portmap isn't running" && exit 0; }
 fi
 
-start() {
-       if [ ! -f /var/lock/subsys/nfsfs ]; then
-               # Set the ports lockd should listen on
-               if [ -n "$LOCKD_TCPPORT" ]; then
-                       /sbin/sysctl -w fs.nfs.nlm_tcpport=$LOCKD_TCPPORT >/dev/null 2>&1
-               fi
-               if [ -n "$LOCKD_UDPPORT" ]; then
-                       /sbin/sysctl -w fs.nfs.nlm_udpport=$LOCKD_UDPPORT >/dev/null 2>&1
-               fi
-
-               # Special case /usr first
-               if ! awk '{ if ($2 == "/usr" && $3 ~ /^nfs(4$|$)/ && $4 !~ /noauto/) exit 1}' /etc/fstab ; then
-                       run_cmd "Mounting /usr filesystem" mount /usr
-                       # In case of /usr over NFS idmapd, gssd and lockd may not start
-                       # check if they're running and try to start them if not
-                       /sbin/service idmapd status >/dev/null || /sbin/service idmapd start
-                       /sbin/service gssd status >/dev/null || /sbin/service gssd start
-                       /sbin/service nfslock status >/dev/null || /sbin/service nfslock start
-               fi
-               run_cmd "Mounting NFS filesystems" mount -a -t nfs,nfs4
-               touch /var/lock/subsys/nfsfs
+if [ -z "$NFSUMOUNT_IGNORE" ]; then
+       NFSUMOUNT_IGNORE="/ /usr"
+fi
 
-       else
+start() {
+       if [ -f /var/lock/subsys/nfsfs ]; then
            msg_already_running "NFSFS"
+               return
+       fi
+
+       # Set the ports lockd should listen on
+       if [ -n "$LOCKD_TCPPORT" ]; then
+               /sbin/sysctl -w fs.nfs.nlm_tcpport=$LOCKD_TCPPORT >/dev/null 2>&1
+       fi
+       if [ -n "$LOCKD_UDPPORT" ]; then
+               /sbin/sysctl -w fs.nfs.nlm_udpport=$LOCKD_UDPPORT >/dev/null 2>&1
        fi
+
+       run_cmd "Mounting NFS filesystems" mount -a -t nfs,nfs4
+       touch /var/lock/subsys/nfsfs
 }
 
 stop() {
@@ -72,13 +67,25 @@ stop() {
        show "Unmounting NFS filesystems"
        busy
        retry=3
-       remaining=$(awk '$3 ~ /^nfs(4$|$)/ {print $2}' $fsfile)
+       remaining=$(awk -v ig="^($NFSUMOUNT_IGNORE)$" 'BEGIN { gsub(/[\t ]+/, "|", ig); } \
+                       $3 ~ /^nfs(4$|$)/ && $2 !~ ig {print $2}' $fsfile)
        while [ -n "$remaining" -a $retry -gt 0 ]; do
-               fuser -msk -TERM `awk '$3 ~ /^nfs(4$|$)/ {print $2}' < $fsfile`
+               fuser -msk -TERM `awk -v ig="^($NFSUMOUNT_IGNORE)$" 'BEGIN { gsub(/[\t ]+/, "|", ig); } \
+                                       $3 ~ /^nfs(4$|$)/ && $2 !~ ig {print $2}' $fsfile`
                sleep 2
-               fuser -msk -KILL `awk '$3 ~ /^nfs(4$|$)/ {print $2}' < $fsfile`
-               umount -a -f -t nfs,nfs4
-               remaining=$(awk '$3 ~ /^nfs(4$|$)/ {print $2}' $fsfile)
+               fuser -msk -KILL `awk -v ig="^($NFSUMOUNT_IGNORE)$" 'BEGIN { gsub(/[\t ]+/, "|", ig); } \
+                                       $3 ~ /^nfs(4$|$)/ && $2 !~ ig {print $2}' $fsfile`
+               # Sort filesystems to unmount in reverse order
+               rem=""
+               for r in $(awk -v ig="^($NFSUMOUNT_IGNORE)$" 'BEGIN { gsub(/[\t ]+/, "|", ig); } \
+                               $3 ~ /^nfs(4$|$)/ && $2 !~ ig {print $2}' $fsfile) ; do
+                       rem="$r $rem"
+               done
+               for fs in $rem ; do
+                       umount $fs
+               done
+               remaining=$(awk -v ig="^($NFSUMOUNT_IGNORE)$" 'BEGIN { gsub(/[\t ]+/, "|", ig); } \
+                               $3 ~ /^nfs(4$|$)/ && $2 !~ ig {print $2}' $fsfile)
                retry=$(($retry-1))
        done
        ok
@@ -93,6 +100,13 @@ case "$1" in
   stop)
        stop
        ;;
+  restart)
+       stop
+       start
+       ;;
+  reload|force-reload)
+       mount -a -t nfs,nfs4
+       ;;
   status)
        if [ -f /proc/mounts ]; then
                echo "Configured NFS mountpoints:"
@@ -105,13 +119,6 @@ case "$1" in
                echo "/proc filesystem unavailable"
        fi
        ;;
-  restart)
-       stop
-       start
-       ;;
-  reload|force-reload)
-       mount -a -t nfs,nfs4
-       ;;
   *)
        msg_usage "$0 {start|stop|restart|reload|force-reload|status}"
        exit 3
This page took 0.053449 seconds and 4 git commands to generate.