X-Git-Url: http://git.pld-linux.org/?a=blobdiff_plain;f=nfs.init;h=0da6062e1f467d2d9646c2c351f8981f3c2033ae;hb=5406419cd9a89792318c41211eb4cd848e1a32e8;hp=56f0924de36408abf6dc339d0fb0360843aab9e2;hpb=bf36188d598fe5d5886ecc3020d44b62685d06b9;p=packages%2Fnfs-utils.git diff --git a/nfs.init b/nfs.init index 56f0924..0da6062 100644 --- a/nfs.init +++ b/nfs.init @@ -3,7 +3,7 @@ # nfs This shell script takes care of starting and stopping # the NFS services. # -# chkconfig: 345 60 20 +# chkconfig: 345 13 81 # description: NFS is a popular protocol for file sharing across TCP/IP \ # networks. This service provides NFS server functionality, \ # which is configured via the /etc/exports file. @@ -15,103 +15,145 @@ # Get network config . /etc/sysconfig/network -# Get service config +# Get service configs +[ -f /etc/sysconfig/nfslock ] && . /etc/sysconfig/nfslock [ -f /etc/sysconfig/nfsd ] && . /etc/sysconfig/nfsd +[ -n "$NFSv1" ] || NFSv1="yes" +[ -n "$NFSv2" ] || NFSv2="yes" +[ -n "$NFSv3" ] || NFSv3="yes" +[ -n "$NFSv4" ] || NFSv4="yes" + # Check that networking is up. -if is_no "${NETWORKING}"; then - msg_Network_Down NFSD - exit 1 +if is_yes "${NETWORKING}"; then + if [ ! -f /var/lock/subsys/network -a "$1" != stop -a "$1" != status ]; then + msg_network_down "NFS daemon" + exit 1 + fi +else + exit 0 fi -if [ -x /sbin/pidof ] && [ "$1" != "stop" ]; then - [ -z "`/sbin/pidof portmap`" ] && echo "Error: portmap isn't running" && exit 0 +if [ "$1" != "stop" ]; then + check_portmapper || { nls "Error: portmap isn't running" && exit 0; } fi -# Sanity checks -[ -x /usr/sbin/rpc.nfsd ] || exit 0 -[ -x /usr/sbin/rpc.mountd ] || exit 0 -[ -f /etc/exports ] || exit 0 +start() { + # Check if the service is already running? + if [ ! -f /var/lock/subsys/nfs ]; then + if ! grep -q nfsd /proc/mounts ; then + modprobe -s nfsd > /dev/null 2>&1 + run_cmd "Mounting /proc/fs/nfsd filesystem" mount -t nfsd nfsd /proc/fs/nfsd + fi -# See how we were called. -case "$1" in - start) - # Start daemons. - if [ "$NFSDTYPE" = "U" ] ; then - msg_starting "NFS mountd" - daemon rpc.mountd - msg_starting "NFS daemon" - daemon rpc.nfsd - else - msg_starting "NFS" + # 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 + + for vers in 1 2 3 4 ; do + is_yes $(eval echo \$NFSv$vers) || \ + RPCMOUNTOPTIONS="$RPCMOUNTOPTIONS --no-nfs-version $vers" + done + + [ -n "$MOUNTD_PORT" ] && RPCMOUNTOPTIONS="$RPCMOUNTOPTIONS -p $MOUNTD_PORT" + + # Start daemons. + msg_starting "NFS exportfs" daemon /usr/sbin/exportfs -r msg_starting "NFS mountd" - daemon rpc.mountd $RPCMOUNTDOPTS + daemon rpc.mountd $RPCMOUNTOPTIONS msg_starting "NFS daemon" daemon rpc.nfsd $RPCNFSDCOUNT + touch /var/lock/subsys/nfs + else + msg_already_running "NFS daemon" fi - touch /var/lock/subsys/nfs - ;; - stop) - # Stop daemons. - if [ "$NFSDTYPE" = "U" ] ; then - msg_stopping "NFS mountd" - killproc rpc.mountd +} + +stop() { + if [ -f /var/lock/subsys/nfs ]; then + # Stop daemons. msg_stopping "NFS daemon" - killproc rpc.nfsd - else + killproc nfsd -QUIT msg_stopping "NFS mountd" killproc rpc.mountd - msg_stopping "NFS daemon" - killproc nfsd -QUIT msg_stopping "NFS" daemon /usr/sbin/exportfs -au - fi - rm -f /var/lock/subsys/nfs - ;; - status) - status rpc.mountd - if [ "$NFSDTYPE" = "U" ] ; then - status rpc.nfsd + rm -f /var/lock/subsys/nfs else - status nfsd + msg_not_running "NFS" fi +} + +RETVAL=0 +# See how we were called. +case "$1" in + start) + start + ;; + stop) + stop ;; restart) - if [ "$NFSDTYPE" = "U" ] ; then - $0 stop - $0 start - else - show "Restarting NFS services (killing)" - killproc rpc.mountd - show "Restarting NFS services (starting)" - daemon rpc.mountd $RPCMOUNTDOPTS + stop + start + /sbin/service idmapd status >/dev/null && /sbin/service idmapd reload + /sbin/service svcgssd status >/dev/null && /sbin/service svcgssd restart + ;; + reload|force-reload) + if [ -f /var/lock/subsys/nfs ]; then + msg_reloading "NFS" + busy /usr/sbin/exportfs -r - touch /var/lock/subsys/nfs + [ $? -ne 0 ] && RETVAL=7 + if [ $RETVAL -eq 0 ]; then + ok + /sbin/service idmapd status >/dev/null && /sbin/service idmapd reload + /sbin/service svcgssd status >/dev/null && /sbin/service svcgssd restart + else + died + fi + else + msg_not_running "NFS" + exit 7 fi ;; - reload) - [ "$NFSDTYPE" = "U" ] && exit 0 - /usr/sbin/exportfs - touch /var/lock/subsys/nfs - ;; probe) - [ "$NFSDTYPE" = "U" ] && exit 0 - if [ ! -f /var/lock/subsys/nfs ] ; then - echo start; exit 0 + if [ ! -f /var/lock/subsys/nfs ]; then + echo start + exit 0 fi /sbin/pidof rpc.mountd >/dev/null 2>&1; MOUNTD="$?" /sbin/pidof nfsd >/dev/null 2>&1; NFSD="$?" - if [ $MOUNTD = 1 -o $NFSD = 1 ] ; then - echo restart; exit 0 + if [ $MOUNTD = 1 -o $NFSD = 1 ]; then + echo restart + exit 0 fi - if [ /etc/exports -nt /var/lock/subsys/nfs ] ; then - echo reload; exit 0 + if [ /etc/exports -nt /var/lock/subsys/nfs ]; then + echo reload + exit 0 fi ;; + status) + echo "Configured NFS exports:" + grep -v "^#" /etc/exports + echo + echo "Active NFS exports:" + /usr/sbin/exportfs -v + echo + status rpc.mountd + RETVAL=$? + status nfsd + RET=$? + [ $RETVAL -eq 0 ] && RETVAL=$RET + ;; *) - msg_Usage "$0 {start|stop|status|restart|reload|probe}" - exit 1 + msg_usage "$0 {start|stop|restart|reload|force-reload|probe|status}" + exit 3 esac -exit 0 +exit $RETVAL