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 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 02/15] conffile: add bool support NeilBrown
2016-12-02 3:58 ` [PATCH 01/15] Add man-page describing /etc/nfs.conf NeilBrown
2016-12-02 3:58 ` [PATCH 09/15] conffile: add support for include files NeilBrown
2016-12-02 3:58 ` [PATCH 06/15] Add /etc/nfs.conf support for sm-notify NeilBrown
2016-12-02 3:58 ` [PATCH 11/15] conffile: ignore setting of empty string NeilBrown
2016-12-02 3:58 ` [PATCH 07/15] conffile: free image of config file after parsing 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 10/15] conffile: strip "quotes" from values in conf file NeilBrown
2016-12-02 3:58 ` [PATCH 15/15] Add nfs.systemd man page NeilBrown
2016-12-02 3:58 ` [PATCH 12/15] conffile: allow $name expansion of tag values NeilBrown
2016-12-02 3:58 ` [PATCH 14/15] systemd: Remove the nfs-config.service NeilBrown
2016-12-02 3:58 ` [PATCH 13/15] statd: allow --no-notify to be passed via environment variable 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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).