Update the /etc/rc.d scripts for mountd and nfsd so they

can use the "-o" option to force the old NFS server to run.
Running the old NFS server is enabled by setting
oldnfs_server_enable="YES". The scripts will only enable
providing service for NFSv4 if nfsv4_server_enable="YES"
is set.

Reviewed by:	dougb (rc)
This commit is contained in:
Rick Macklem 2011-04-26 00:22:17 +00:00
parent e2314c6ccb
commit 6bb544780b
3 changed files with 30 additions and 17 deletions

View File

@ -323,6 +323,7 @@ amd_map_program="NO" # Can be set to "ypcat -k amd.master"
nfs_client_enable="NO" # This host is an NFS client (or NO). nfs_client_enable="NO" # This host is an NFS client (or NO).
nfs_access_cache="60" # Client cache timeout in seconds nfs_access_cache="60" # Client cache timeout in seconds
nfs_server_enable="NO" # This host is an NFS server (or NO). nfs_server_enable="NO" # This host is an NFS server (or NO).
oldnfs_server_enable="NO" # Run the old NFS server (YES/NO).
nfs_server_flags="-u -t -n 4" # Flags to nfsd (if enabled). nfs_server_flags="-u -t -n 4" # Flags to nfsd (if enabled).
mountd_enable="NO" # Run mountd (or NO). mountd_enable="NO" # Run mountd (or NO).
mountd_flags="-r" # Flags to mountd (if NFS server enabled). mountd_flags="-r" # Flags to mountd (if NFS server enabled).

View File

@ -37,11 +37,10 @@ mountd_precmd()
fi fi
fi fi
# If nfsv4_server_enable is yes, force use of the experimental # If oldnfs_server_enable is yes, force use of the old NFS server
# server
# #
if checkyesno nfsv4_server_enable; then if checkyesno oldnfs_server_enable; then
rc_flags="-e ${rc_flags}" rc_flags="-o ${rc_flags}"
fi fi
if checkyesno zfs_enable; then if checkyesno zfs_enable; then

View File

@ -19,19 +19,8 @@ sig_stop="USR1"
nfsd_precmd() nfsd_precmd()
{ {
if checkyesno nfsv4_server_enable; then if checkyesno oldnfs_server_enable; then
# If nfsv4_server_enable is yes, force use rc_flags="-o ${nfs_server_flags}"
# of the experimental server
#
rc_flags="-e ${nfs_server_flags}"
if ! checkyesno nfsuserd_enable && \
! /etc/rc.d/nfsuserd forcestatus 1>/dev/null 2>&1
then
force_depend nfsuserd || return 1
fi
else
rc_flags="${nfs_server_flags}"
if ! sysctl vfs.nfsrv >/dev/null 2>&1; then if ! sysctl vfs.nfsrv >/dev/null 2>&1; then
force_depend nfsserver || return 1 force_depend nfsserver || return 1
@ -41,6 +30,30 @@ nfsd_precmd()
echo 'NFS on reserved port only=YES' echo 'NFS on reserved port only=YES'
sysctl vfs.nfsrv.nfs_privport=1 > /dev/null sysctl vfs.nfsrv.nfs_privport=1 > /dev/null
fi fi
else
rc_flags="${nfs_server_flags}"
# Load the modules now, so that the vfs.newnfs sysctl
# oids are available.
load_kld nfsd
if checkyesno nfs_reserved_port_only; then
echo 'NFS on reserved port only=YES'
sysctl vfs.newnfs.nfs_privport=1 > /dev/null
fi
if checkyesno nfsv4_server_enable; then
if ! checkyesno nfsuserd_enable && \
! /etc/rc.d/nfsuserd forcestatus 1>/dev/null 2>&1
then
if ! force_depend nfsuserd; then
err 1 "Cannot run nfsuserd"
fi
fi
else
echo 'NFSv4 is disabled'
sysctl vfs.newnfs.server_max_nfsvers=3 > /dev/null
fi
fi fi
if ! checkyesno rpcbind_enable && \ if ! checkyesno rpcbind_enable && \