summaryrefslogtreecommitdiff
path: root/source/n/nfs-utils/rc.nfsd
blob: 06c34b018d855f5d19bc64a0b55c06250901f891 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
#!/bin/sh
# Start/stop/restart the NFS server.
#
# This is an init script for the knfsd NFS daemons.
# To use NFS, you must first set up /etc/exports.
# See exports(5) for information on /etc/exports format.
#
# Written for Slackware Linux by Patrick J. Volkerding <volkerdi@slackware.com>.

# Source default settings:
if [ -r /etc/default/rpc ]; then
  . /etc/default/rpc
fi
if [ -r /etc/default/nfs ]; then
  . /etc/default/nfs
fi

nfsd_start() {
  # Sanity checks.  Exit if there's no /etc/exports, or if there aren't any
  # shares defined in it.
  if [ ! -r /etc/exports ]; then # no config file, exit:
    exit
  elif ! grep -v '^#' /etc/exports | grep '/' 1> /dev/null 2> /dev/null ; then
    exit # no uncommented shares in /etc/exports
  fi

  # Without this directory the logs will complain with
  # 'NFSD: Unable to end grace period'.
  NFSV4RECOVERYDIR=$(cat /proc/fs/nfsd/nfsv4recoverydir)
  if [ -r /proc/fs/nfsd/nfsv4recoverydir -a ! -d "$NFSV4RECOVERYDIR" ]; then
    mkdir "$NFSV4RECOVERYDIR"
    chown -R rpc:rpc "$NFSV4RECOVERYDIR"
  fi

  # If we do not detect nfsd support built into the kernel (or previously
  # loaded as a module), we will try to load the nfsd.ko kernel module:
  if [ ! -r /proc/1/net/rpc/nfsd ]; then
    /sbin/modprobe nfsd
  fi

  # For kernels newer than 2.4.x, use the new way of handling nfs client requests.
  if [ ! "$(/bin/uname -r | /bin/cut -f 1,2 -d .)" = "2.4" ]; then
    if grep -wq nfsd /proc/filesystems 2> /dev/null ; then
      if grep -vwq nfsd /proc/mounts 2> /dev/null ; then
        /sbin/mount -t nfsd nfsd /proc/fs/nfs 2> /dev/null
      fi
    fi
  fi

  # If basic RPC services are not running, start them:
  if ! ps axc | grep -q rpc.statd ; then
    if [ -r /etc/rc.d/rc.rpc ]; then
      sh /etc/rc.d/rc.rpc start
    else
      # Sure, we tested for rpc.statd, but this is the probable cause:
      echo "FATAL:  Can't start NFS server without portmap package."
      sleep 5
      exit 1
    fi
  fi

  echo "Starting NFS server daemons:"

  if [ -x /usr/sbin/exportfs ]; then
    echo "  /usr/sbin/exportfs -r"
    /usr/sbin/exportfs -r
  fi

  if [ -x /usr/sbin/rpc.rquotad ]; then
    if [ -n "$RPC_RQUOTAD_PORT" ]; then
      RPC_RQUOTAD_OPTS="$RPC_RQUOTAD_OPTS -p $RPC_RQUOTAD_PORT"
    fi
    echo "  /usr/sbin/rpc.rquotad $RPC_RQUOTAD_OPTS"
    /usr/sbin/rpc.rquotad $RPC_RQUOTAD_OPTS
  fi

  # Start nfsd servers - 8 if not set otherwise (an old Sun standard):
  if [ -x /usr/sbin/rpc.nfsd ]; then
    if [ -z "$RPC_NFSD_COUNT" ]; then
      RPC_NFSD_COUNT=8
    fi
    echo "  /usr/sbin/rpc.nfsd $RPC_NFSD_OPTS $RPC_NFSD_COUNT"
    /usr/sbin/rpc.nfsd $RPC_NFSD_OPTS $RPC_NFSD_COUNT
  fi

  if [ -x /usr/sbin/rpc.mountd ]; then
    if [ -n "$RPC_MOUNTD_PORT" ]; then
      RPC_MOUNTD_OPTS="$RPC_MOUNTD_OPTS -p $RPC_MOUNTD_PORT"
    fi
    echo "  /usr/sbin/rpc.mountd $RPC_MOUNTD_OPTS"
    /usr/sbin/rpc.mountd $RPC_MOUNTD_OPTS
  fi

}

nfsd_stop() {
  killall rpc.mountd 2> /dev/null
  killall nfsd 2> /dev/null
  sleep 1
  killall -9 nfsd 2> /dev/null # make sure :)
  killall rpc.rquotad 2> /dev/null
  /usr/sbin/exportfs -au 2> /dev/null
}

nfsd_restart() {
  nfsd_stop
  sleep 1
  nfsd_start
}

case "$1" in
'start')
  nfsd_start
  ;;
'stop')
  nfsd_stop
  ;;
'restart')
  nfsd_restart
  ;;
*)
  echo "usage $0 start|stop|restart"
esac