From: bfields@fieldses.org (J. Bruce Fields)
To: NeilBrown <neilb@suse.com>
Cc: "J. Bruce Fields" <bfields@redhat.com>,
Steve Dickson <SteveD@redhat.com>,
linux-nfs@vger.kernel.org
Subject: Re: [PATCH 03/15] Add /etc/nfs.conf support to rpc.nfsd
Date: Mon, 5 Dec 2016 17:27:50 -0500 [thread overview]
Message-ID: <20161205222750.GC20652@fieldses.org> (raw)
In-Reply-To: <148065110833.28046.2561331715736018574.stgit@noble>
On Fri, Dec 02, 2016 at 02:58:28PM +1100, NeilBrown wrote:
> I haven't added -H support, but everything else should be able to be
> set through /etc/nfs.conf.
I'm unclear--is this just a temporary omission for the purposes of this
RFC, or is there some reason you think -H shouldn't be set in nfs.conf?
--b.
>
> Signed-off-by: NeilBrown <neilb@suse.com>
> ---
> systemd/nfs.conf.man | 24 ++++++++++++++++++++++++
> utils/nfsd/nfsd.c | 36 ++++++++++++++++++++++++++++++++++++
> utils/nfsd/nfsd.man | 49 ++++++++++++++++++++++++++++++++++++++++++++++---
> 3 files changed, 106 insertions(+), 3 deletions(-)
>
> diff --git a/systemd/nfs.conf.man b/systemd/nfs.conf.man
> index 1f524d8fe74e..6ac6c65a81d9 100644
> --- a/systemd/nfs.conf.man
> +++ b/systemd/nfs.conf.man
> @@ -76,8 +76,32 @@ file is the only way to configure this program. See
> .BR nfsdcltrack (8)
> for details.
>
> +.TP
> +.B nfsd
> +Recognized values:
> +.BR threads ,
> +.BR grace-time ,
> +.BR lease-time ,
> +.BR udp ,
> +.BR tcp ,
> +.BR vers2 ,
> +.BR vers3 ,
> +.BR vers4 ,
> +.BR vers4.0 ,
> +.BR vers4.1 ,
> +.BR vers4.2 ,
> +.BR rdma .
> +
> +Version and protocol values are Boolean values as described above.
> +Threads and the two times are integers.
> +.B rdma
> +is a service name or number. See
> +.BR rpc.nfsd (8)
> +for details.
> +
> .SH FILES
> .I /etc/nfs.conf
> .SH SEE ALSO
> .BR nfsdcltrack (8),
> +.BR rpc.nfsd (8),
> .BR nfsmount.conf (5).
> diff --git a/utils/nfsd/nfsd.c b/utils/nfsd/nfsd.c
> index 9a65877f30c3..62b2876948c3 100644
> --- a/utils/nfsd/nfsd.c
> +++ b/utils/nfsd/nfsd.c
> @@ -24,6 +24,7 @@
> #include <netinet/in.h>
> #include <arpa/inet.h>
>
> +#include "conffile.h"
> #include "nfslib.h"
> #include "nfssvc.h"
> #include "xlog.h"
> @@ -33,6 +34,8 @@
> #define NFSD_NPROC 8
> #endif
>
> +char *conf_path = NFS_CONFFILE;
> +
> static void usage(const char *);
>
> static struct option longopts[] =
> @@ -76,6 +79,39 @@ main(int argc, char **argv)
> xlog_syslog(0);
> xlog_stderr(1);
>
> + conf_init();
> + count = conf_get_num("nfsd", "threads", count);
> + grace = conf_get_num("nfsd", "grace-time", grace);
> + lease = conf_get_num("nfsd", "lease-time", lease);
> + rdma_port = conf_get_str("nfsd", "rdma");
> + if (conf_get_bool("nfsd", "udp", NFSCTL_UDPISSET(protobits)))
> + NFSCTL_UDPSET(protobits);
> + else
> + NFSCTL_UDPUNSET(protobits);
> + if (conf_get_bool("nfsd", "tcp", NFSCTL_TCPISSET(protobits)))
> + NFSCTL_TCPSET(protobits);
> + else
> + NFSCTL_TCPUNSET(protobits);
> + for (i = 2; i <= 4; i++) {
> + char tag[10];
> + sprintf(tag, "vers%d", i);
> + if (conf_get_bool("nfsd", tag, NFSCTL_VERISSET(versbits, i)))
> + NFSCTL_VERSET(versbits, i);
> + else
> + NFSCTL_VERUNSET(versbits, i);
> + }
> + /* We assume the kernel will default all minor versions to 'on',
> + * and allow the config file to disable some.
> + */
> + for (i = 0; i <= NFS4_MAXMINOR; i++) {
> + char tag[20];
> + sprintf(tag, "vers4.%d", i);
> + if (!conf_get_bool("nfsd", tag, 1)) {
> + NFSCTL_VERSET(minorversset, i);
> + NFSCTL_VERUNSET(minorversset, i);
> + }
> + }
> +
> while ((c = getopt_long(argc, argv, "dH:hN:V:p:P:sTUrG:L:", longopts, NULL)) != EOF) {
> switch(c) {
> case 'd':
> diff --git a/utils/nfsd/nfsd.man b/utils/nfsd/nfsd.man
> index 3ba847e2938f..7b9fbf21a947 100644
> --- a/utils/nfsd/nfsd.man
> +++ b/utils/nfsd/nfsd.man
> @@ -95,11 +95,11 @@ New file open requests (NFSv4) and new file locks (NLM) will not be
> allowed until after this time has passed to allow clients to recover state.
> .TP
> .I nproc
> -specify the number of NFS server threads. By default, just one
> -thread is started. However, for optimum performance several threads
> +specify the number of NFS server threads. By default, eight
> +threads are started. However, for optimum performance several threads
> should be used. The actual figure depends on the number of and the work
> load created by the NFS clients, but a useful starting point is
> -8 threads. Effects of modifying that number can be checked using
> +eight threads. Effects of modifying that number can be checked using
> the
> .BR nfsstat (8)
> program.
> @@ -114,6 +114,48 @@ In particular
> .B rpc.nfsd 0
> will stop all threads and thus close any open connections.
>
> +.SH CONFIGURATION FILE
> +Many of the options that can be set on the command line can also be
> +controlled through values set in the
> +.B [nfsd]
> +section of the
> +.I /etc/nfs.conf
> +configuration file. Values recognized include:
> +.TP
> +.B threads
> +The number of threads to start.
> +.TP
> +.B grace-time
> +The grace time, for both NFSv4 and NLM, in seconds.
> +.TP
> +.B lease-time
> +The lease time for NFSv4, in seconds.
> +.TP
> +.B rdma
> +Set RDMA port. Use "rdma=nfsrdma" to enable standard port.
> +.TP
> +.B UDP
> +Enable (with "on" or "yes" etc) or disable ("off", "no") UDP support.
> +.TP
> +.B TCP
> +Enable or disable TCP support.
> +.TP
> +.B vers2
> +.TP
> +.B vers3
> +.TP
> +.B vers4
> +Enable or disable a major NFS version. 3 and 4 are normally enabled
> +by default.
> +.TP
> +.B vers4.1
> +.TP
> +.B vers4.2
> +.TP
> +.B vers4.3
> +Setting these to "off" or similar will disable the selected minor
> +versions. All are enabled by default.
> +
> .SH NOTES
> If the program is built with TI-RPC support, it will enable any protocol and
> address family combinations that are marked visible in the
> @@ -125,6 +167,7 @@ database.
> .BR rpc.mountd (8),
> .BR exports (5),
> .BR exportfs (8),
> +.BR nfs.conf (5),
> .BR rpc.rquotad (8),
> .BR nfsstat (8),
> .BR netconfig(5).
>
next prev parent reply other threads:[~2016-12-05 22:27 UTC|newest]
Thread overview: 41+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-12-02 3:58 [RFC PATCH 00/15] Enhance /etc/nfs.conf usage and remove nfs-config.service NeilBrown
2016-12-02 3:58 ` [PATCH 03/15] Add /etc/nfs.conf support to rpc.nfsd NeilBrown
2016-12-05 22:27 ` J. Bruce Fields [this message]
2016-12-05 22:42 ` NeilBrown
2016-12-06 17:52 ` Steve Dickson
2016-12-06 22:30 ` NeilBrown
2016-12-07 14:34 ` Steve Dickson
2016-12-06 18:51 ` Steve Dickson
2016-12-06 22:36 ` NeilBrown
2016-12-07 14:44 ` Steve Dickson
2016-12-07 18:08 ` J. Bruce Fields
2016-12-07 23:14 ` NeilBrown
2016-12-08 0:38 ` Steve Dickson
2016-12-09 22:43 ` J. Bruce Fields
2016-12-20 23:22 ` NeilBrown
2016-12-21 1:55 ` J. Bruce Fields
2016-12-02 3:58 ` [PATCH 02/15] conffile: add bool support NeilBrown
2016-12-02 3:58 ` [PATCH 04/15] Add /etc/nfs.conf support for mountd NeilBrown
2016-12-02 3:58 ` [PATCH 05/15] Add /etc/nfs.conf support for statd NeilBrown
2016-12-02 3:58 ` [PATCH 01/15] Add man-page describing /etc/nfs.conf NeilBrown
2016-12-02 3:58 ` [PATCH 08/15] conffile: split loading of file into a separate function NeilBrown
2016-12-02 3:58 ` [PATCH 11/15] conffile: ignore setting of empty string NeilBrown
2016-12-02 3:58 ` [PATCH 10/15] conffile: strip "quotes" from values in conf file NeilBrown
2016-12-02 3:58 ` [PATCH 06/15] Add /etc/nfs.conf support for sm-notify NeilBrown
2016-12-02 3:58 ` [PATCH 07/15] conffile: free image of config file after parsing NeilBrown
2016-12-02 3:58 ` [PATCH 09/15] conffile: add support for include files NeilBrown
2016-12-02 3:58 ` [PATCH 12/15] conffile: allow $name expansion of tag values NeilBrown
2016-12-02 3:58 ` [PATCH 13/15] statd: allow --no-notify to be passed via environment variable NeilBrown
2016-12-02 3:58 ` [PATCH 14/15] systemd: Remove the nfs-config.service NeilBrown
2016-12-02 3:58 ` [PATCH 15/15] Add nfs.systemd man page NeilBrown
2016-12-02 15:56 ` [RFC PATCH 00/15] Enhance /etc/nfs.conf usage and remove nfs-config.service J. Bruce Fields
2016-12-06 16:55 ` Steve Dickson
2016-12-06 22:38 ` NeilBrown
2016-12-07 14:24 ` Steve Dickson
2016-12-06 17:26 ` J. Bruce Fields
2016-12-06 22:47 ` NeilBrown
2016-12-07 14:19 ` J. Bruce Fields
2016-12-06 19:25 ` Steve Dickson
2016-12-06 22:51 ` NeilBrown
2016-12-07 14:21 ` Steve Dickson
2016-12-20 18:33 ` Steve Dickson
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20161205222750.GC20652@fieldses.org \
--to=bfields@fieldses.org \
--cc=SteveD@redhat.com \
--cc=bfields@redhat.com \
--cc=linux-nfs@vger.kernel.org \
--cc=neilb@suse.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.