cd / # daemons should have root dir as cwd
if grep -q '^/' /etc/exports
then
+ # Having the 'nfsd' filesystem mounted (if available)
+ # make client authentication more reliable.
+ if [ -d /proc/fs/nfsd -a ! -f /proc/fs/nfsd/exports ]
+ then mount -t nfsd nfsd /proc/fs/nfsd
+ fi
printf "Exporting directories for $DESC..."
$PREFIX/sbin/exportfs -r
echo "done."
printf " nfsd"
start-stop-daemon --start --quiet \
--exec $PREFIX/sbin/rpc.nfsd -- $RPCNFSDCOUNT
+
printf " mountd"
+
# make sure 127.0.0.1 is a valid source for requests
ClearAddr=
- if [ -f /proc/net/rpc/auth.unix.ip/channel ] ; then
- if grep -s 127.0.0.1 /proc/net/rpc/auth.unix.ip/content > /dev/null ; then
- : address already known
- else
- echo nfsd 127.0.0.1 2147483647 localhost > /proc/net/rpc/auth.unix.ip/channel
- ClearAddr=yes
- fi
+ if [ -f /proc/net/rpc/auth.unix.ip/channel ]
+ then
+ fgrep -qs 127.0.0.1 /proc/net/rpc/auth.unix.ip/content || {
+ echo "nfsd 127.0.0.1 2147483647 localhost" >/proc/net/rpc/auth.unix.ip/channel
+ ClearAddr=yes
+ }
fi
$PREFIX/bin/rpcinfo -u localhost nfs 3 >/dev/null 2>&1 ||
RPCMOUNTDOPTS="$RPCMOUNTDOPTS --no-nfs-version 3"
- if [ -n "$ClearAddr" ]; then
- echo nfsd 127.0.0.1 1 > /proc/net/rpc/auth.unix.ip/channel
- fi
+ [ -z "$ClearAddr" ] || echo "nfsd 127.0.0.1 1" >/proc/net/rpc/auth.unix.ip/channel
start-stop-daemon --start --quiet \
--exec $PREFIX/sbin/rpc.mountd -- $RPCMOUNTDOPTS
printf "Unexporting directories for $DESC..."
$PREFIX/sbin/exportfs -au
+ if [ -f /proc/fs/nfsd/exports ] ; then umount /proc/fs/nfsd; fi
echo "done."
;;