X-Git-Url: https://git.pld-linux.org/?a=blobdiff_plain;f=nfs.init;h=e3019b211b31db5f3cc89e443276b7085488b799;hb=dc4877f3076ae83af079dbf83d0d6990168051b9;hp=61f2310a19df405703c2157be43837fe6cea0bc8;hpb=9c7e92a157bcb09d8b95a4b22cfe36a0b8e65c85;p=packages%2Fnfs-utils.git diff --git a/nfs.init b/nfs.init index 61f2310..e3019b2 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,140 +15,104 @@ # 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 # Check that networking is up. if is_yes "${NETWORKING}"; then if [ ! -f /var/lock/subsys/network -a "$1" != stop -a "$1" != status ]; then - msg_network_down NFSD + msg_network_down "NFS daemon" exit 1 fi else exit 0 fi -if [ -x /sbin/pidof ] && [ "$1" != "stop" ]; then - [ -z "`/sbin/pidof portmap`" ] && nls "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 + msg_already_running "NFS daemon" + return + fi + + 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 + + # 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 + + # Start daemons. + msg_starting "NFS exportfs" + daemon /usr/sbin/exportfs -r + msg_starting "NFS mountd" + daemon /usr/sbin/rpc.mountd $RPCMOUNTDOPTIONS + msg_starting "NFS daemon" + daemon /usr/sbin/rpc.nfsd $RPCNFSDCOUNT + touch /var/lock/subsys/nfs +} + +stop() { + if [ ! -f /var/lock/subsys/nfs ]; then + msg_not_running "NFS" + return + fi + + # Stop daemons. + msg_stopping "NFS daemon" + killproc nfsd -QUIT + msg_stopping "NFS mountd" + killproc rpc.mountd + msg_stopping "NFS exportfs" + daemon /usr/sbin/exportfs -au + rm -f /var/lock/subsys/nfs +} RETVAL=0 # See how we were called. case "$1" in start) - # Check if the service is already running? - if [ ! -f /var/lock/subsys/nfs ]; then - # Start daemons. - if [ "$NFSDTYPE" = "U" ]; then - msg_starting "NFS mountd" - daemon rpc.mountd $RPCMOUNTOPTIONS - msg_starting "NFS daemon" - daemon rpc.nfsd $RPCNFSDCOUNT - else - modprobe -s nfsd > /dev/null 2>&1 - if [ "$(kernelverser)" -ge "002006" ] && \ - grep -q nfsd /proc/filesystems && \ - ! grep -q nfsd /proc/mounts; then - run_cmd "Mounting /proc/fs/nfsd filesystem" mount -t nfsd nfsd /proc/fs/nfsd - grep -q rpc_pipefs /proc/filesystems && \ - ! grep -q rpc_pipefs /proc/mounts; then - run_cmd "Mounting /var/lib/nfs/rpc_pipefs filesystem" mount -t rpc_pipefs rpc_pipefs /var/lib/nfs/rpc_pipefs - fi - msg_starting "NFS" - daemon /usr/sbin/exportfs -r - msg_starting "NFS mountd" - daemon rpc.mountd $RPCMOUNTOPTIONS - if (grep -q nfs4 /proc/filesystems); then - if [ ! -f /var/lock/subsys/idmapd ]; then - msg_starting "NFS idmapd" - daemon rpc.idmapd $RPCIDMAPOPTIONS - [ $? = 0 ] && touch /var/lock/subsys/idmapd - fi - msg_starting "NFS svcgssd" - daemon rpc.svcgssd $RPCSVCGSSOPTIONS - fi - msg_starting "NFS daemon" - daemon rpc.nfsd $RPCNFSDCOUNT - fi - touch /var/lock/subsys/nfs - else - msg_already_running "NFS" - fi + start ;; stop) - if [ -f /var/lock/subsys/nfs ]; then - # Stop daemons. - if [ "$NFSDTYPE" = "U" ]; then - msg_stopping "NFS mountd" - killproc rpc.mountd - msg_stopping "NFS daemon" - killproc rpc.nfsd - else - msg_stopping "NFS mountd" - killproc rpc.mountd - msg_stopping "NFS daemon" - killproc nfsd -QUIT - if (grep -q nfs4 /proc/filesystems); then - msg_stopping "NFS svcgssd" - killproc rpc.svcgssd - if [ -f /var/lock/subsys/idmapd -a ! -f /var/lock/subsys/nfsfs ]; then - msg_stopping "NFS idmapd" - killproc rpc.idmapd - rm -f /var/lock/subsys/idmapd - fi - fi - msg_stopping "NFS" - daemon /usr/sbin/exportfs -au - fi - rm -f /var/lock/subsys/nfs - else - msg_not_running "NFS" - fi - ;; - status) - status rpc.mountd - RETVAL=$? - if [ "$NFSDTYPE" = "U" ]; then - status rpc.nfsd - else - status nfsd - fi - RET=$? - [ $RETVAL -eq 0 ] && RETVAL=$RET + stop ;; restart) - $0 stop - $0 start - exit $? + stop + start + /sbin/service idmapd status >/dev/null && /sbin/service idmapd reload + /sbin/service svcgssd status >/dev/null && /sbin/service svcgssd restart ;; - force-reload) - if [ "$NFSDTYPE" = "U" ]; then - $0 restart - else - $0 reload - fi - exit $? - ;; - reload) - [ "$NFSDTYPE" = "U" ] && exit 0 + reload|force-reload) if [ -f /var/lock/subsys/nfs ]; then msg_reloading "NFS" busy - /usr/sbin/exportfs + /usr/sbin/exportfs -r [ $? -ne 0 ] && RETVAL=7 - [ $RETVAL -eq 0 ] && ok || died + 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" >&2 + msg_not_running "NFS" exit 7 fi ;; probe) - [ "$NFSDTYPE" = "U" ] && exit 0 if [ ! -f /var/lock/subsys/nfs ]; then echo start exit 0 @@ -164,6 +128,19 @@ case "$1" in 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|restart|reload|force-reload|probe|status}" exit 3