From: Mike Snitzer <snitzer@kernel.org>
To: Chuck Lever <chuck.lever@oracle.com>
Cc: linux-nfs@vger.kernel.org, Jeff Layton <jlayton@kernel.org>,
Anna Schumaker <anna@kernel.org>,
Trond Myklebust <trondmy@hammerspace.com>,
NeilBrown <neilb@suse.de>,
linux-fsdevel@vger.kernel.org
Subject: Re: [PATCH v13 00/19] nfs/nfsd: add support for localio
Date: Tue, 27 Aug 2024 12:56:42 -0400 [thread overview]
Message-ID: <Zs4FSgwOqbqt6JYJ@kernel.org> (raw)
In-Reply-To: <ZstRwsA1AGRVzFbF@tissot.1015granger.net>
On Sun, Aug 25, 2024 at 11:46:10AM -0400, Chuck Lever wrote:
> On Fri, Aug 23, 2024 at 02:13:58PM -0400, Mike Snitzer wrote:
> > These latest changes are available in my git tree here:
> > https://git.kernel.org/pub/scm/linux/kernel/git/snitzer/linux.git/log/?h=nfs-localio-for-next
> >
> > Changes since v12:
> > - Rebased to rearrange code to avoid "churn" that Jeff Layton felt
> > distracting (biggest improvement came from folding switch from
> > struct file to nfsd_file changes in from the start of the series)
> > - Updated relevant patch headers accordingly.
> > - Updated localio.rst to provide more performance data.
> > - Dropped v12's buggy "nfsd: fix nfsfh tracepoints to properly handle
> > NULL rqstp" patch -- fixing localio to support fh_verify tracepoints
> > will need more think-time and discussion, but they aren't of
> > critical importance so fixing them doesn't need to hold things up.
> >
> > Please also see v12's patch header for v12's extensive changes:
> > https://marc.info/?l=linux-nfs&m=172409139907981&w=2
> >
> > Thanks,
> > Mike
> >
> > Mike Snitzer (9):
> > nfs_common: factor out nfs_errtbl and nfs_stat_to_errno
> > nfs_common: factor out nfs4_errtbl and nfs4_stat_to_errno
> > nfs: factor out {encode,decode}_opaque_fixed to nfs_xdr.h
> > SUNRPC: remove call_allocate() BUG_ONs
> > nfs_common: add NFS LOCALIO auxiliary protocol enablement
> > nfsd: implement server support for NFS_LOCALIO_PROGRAM
> > nfs: pass struct nfsd_file to nfs_init_pgio and nfs_init_commit
> > nfs: implement client support for NFS_LOCALIO_PROGRAM
> > nfs: add Documentation/filesystems/nfs/localio.rst
> >
> > NeilBrown (3):
> > nfsd: factor out __fh_verify to allow NULL rqstp to be passed
> > nfsd: add nfsd_file_acquire_local()
> > SUNRPC: replace program list with program array
> >
> > Trond Myklebust (4):
> > nfs: enable localio for non-pNFS IO
> > pnfs/flexfiles: enable localio support
> > nfs/localio: use dedicated workqueues for filesystem read and write
> > nfs: add FAQ section to Documentation/filesystems/nfs/localio.rst
> >
> > Weston Andros Adamson (3):
> > SUNRPC: add rpcauth_map_clnt_to_svc_cred_local
> > nfsd: add localio support
> > nfs: add localio support
> >
> > Documentation/filesystems/nfs/localio.rst | 276 ++++++++
> > fs/Kconfig | 3 +
> > fs/nfs/Kconfig | 15 +
> > fs/nfs/Makefile | 1 +
> > fs/nfs/client.c | 15 +-
> > fs/nfs/filelayout/filelayout.c | 6 +-
> > fs/nfs/flexfilelayout/flexfilelayout.c | 142 +++-
> > fs/nfs/flexfilelayout/flexfilelayout.h | 2 +
> > fs/nfs/flexfilelayout/flexfilelayoutdev.c | 6 +
> > fs/nfs/inode.c | 57 +-
> > fs/nfs/internal.h | 61 +-
> > fs/nfs/localio.c | 784 ++++++++++++++++++++++
> > fs/nfs/nfs2xdr.c | 70 +-
> > fs/nfs/nfs3xdr.c | 108 +--
> > fs/nfs/nfs4xdr.c | 84 +--
> > fs/nfs/nfstrace.h | 61 ++
> > fs/nfs/pagelist.c | 16 +-
> > fs/nfs/pnfs_nfs.c | 2 +-
> > fs/nfs/write.c | 12 +-
> > fs/nfs_common/Makefile | 5 +
> > fs/nfs_common/common.c | 134 ++++
> > fs/nfs_common/nfslocalio.c | 194 ++++++
> > fs/nfsd/Kconfig | 15 +
> > fs/nfsd/Makefile | 1 +
> > fs/nfsd/export.c | 8 +-
> > fs/nfsd/filecache.c | 90 ++-
> > fs/nfsd/filecache.h | 5 +
> > fs/nfsd/localio.c | 183 +++++
> > fs/nfsd/netns.h | 8 +-
> > fs/nfsd/nfsctl.c | 2 +-
> > fs/nfsd/nfsd.h | 6 +-
> > fs/nfsd/nfsfh.c | 122 ++--
> > fs/nfsd/nfsfh.h | 5 +
> > fs/nfsd/nfssvc.c | 100 ++-
> > fs/nfsd/trace.h | 3 +-
> > fs/nfsd/vfs.h | 10 +
> > include/linux/nfs.h | 9 +
> > include/linux/nfs_common.h | 17 +
> > include/linux/nfs_fs_sb.h | 10 +
> > include/linux/nfs_xdr.h | 20 +-
> > include/linux/nfslocalio.h | 56 ++
> > include/linux/sunrpc/auth.h | 4 +
> > include/linux/sunrpc/svc.h | 7 +-
> > net/sunrpc/auth.c | 22 +
> > net/sunrpc/clnt.c | 6 -
> > net/sunrpc/svc.c | 68 +-
> > net/sunrpc/svc_xprt.c | 2 +-
> > net/sunrpc/svcauth_unix.c | 3 +-
> > 48 files changed, 2434 insertions(+), 402 deletions(-)
> > create mode 100644 Documentation/filesystems/nfs/localio.rst
> > create mode 100644 fs/nfs/localio.c
> > create mode 100644 fs/nfs_common/common.c
> > create mode 100644 fs/nfs_common/nfslocalio.c
> > create mode 100644 fs/nfsd/localio.c
> > create mode 100644 include/linux/nfs_common.h
> > create mode 100644 include/linux/nfslocalio.h
> >
> > --
> > 2.44.0
> >
>
> I've looked over the NFSD changes in this patch set. Some of them
> look ready to go (I've Acked those), others still need a little TLC.
>
> For me, the big picture questions that remain are:
>
> * How do we ensure that export options that modify RPC user
> translation (eg, all_squash) continue to work as expected on
> LOCALIO mounts?
>
> * How do we ensure that a "stolen" FH can't be exploited by an NFS
> client running in a local container that does not have access to
> an export (server should return NFSERR_STALE)?
>
> * Has LOCALIO been tested with two or more NFS servers running on
> the local system? One assumes they would be in separate
> containers.
>
> The scenario I'm thinking of is two tenants, Pepsi and Coke, running
> in containers on the same physical host. They might want their own
> separate NFS servers, or they might share one server with
> appropriate access controls on the exports. Both of these scenarios
> need to ensure that Pepsi and Coke cannot open each other's files
> via LOCALIO.
Each server instance is isolated in their respective nfsd_net. And
localio was made to build on that isolation. So all creds used, etc
are specific to each nfsd instance.
I haven't verified these scenarios "just work" as expected but localio
preserves all the same checking and upcalls of standard NFS uses.
Mike
next prev parent reply other threads:[~2024-08-27 16:56 UTC|newest]
Thread overview: 55+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-08-23 18:13 [PATCH v13 00/19] nfs/nfsd: add support for localio Mike Snitzer
2024-08-23 18:13 ` [PATCH v13 01/19] nfs_common: factor out nfs_errtbl and nfs_stat_to_errno Mike Snitzer
2024-08-23 18:14 ` [PATCH v13 02/19] nfs_common: factor out nfs4_errtbl and nfs4_stat_to_errno Mike Snitzer
2024-08-23 18:14 ` [PATCH v13 03/19] nfs: factor out {encode,decode}_opaque_fixed to nfs_xdr.h Mike Snitzer
2024-08-23 18:14 ` [PATCH v13 04/19] nfsd: factor out __fh_verify to allow NULL rqstp to be passed Mike Snitzer
2024-08-25 15:32 ` Chuck Lever
2024-08-25 23:44 ` NeilBrown
2024-08-26 14:51 ` Chuck Lever
2024-08-28 17:01 ` Chuck Lever
2024-08-29 0:30 ` Mike Snitzer
2024-08-29 0:32 ` Mike Snitzer
2024-08-27 18:58 ` Mike Snitzer
2024-08-27 19:26 ` Chuck Lever
2024-08-27 19:35 ` Mike Snitzer
2024-08-23 18:14 ` [PATCH v13 05/19] nfsd: add nfsd_file_acquire_local() Mike Snitzer
2024-08-25 15:18 ` Chuck Lever
2024-08-23 18:14 ` [PATCH v13 06/19] SUNRPC: remove call_allocate() BUG_ONs Mike Snitzer
2024-08-23 18:14 ` [PATCH v13 07/19] SUNRPC: add rpcauth_map_clnt_to_svc_cred_local Mike Snitzer
2024-08-25 15:17 ` Chuck Lever
2024-08-27 16:08 ` Mike Snitzer
2024-08-23 18:14 ` [PATCH v13 08/19] SUNRPC: replace program list with program array Mike Snitzer
2024-08-25 15:14 ` Chuck Lever
2024-08-23 18:14 ` [PATCH v13 09/19] nfs_common: add NFS LOCALIO auxiliary protocol enablement Mike Snitzer
2024-08-26 0:32 ` NeilBrown
2024-08-27 17:45 ` Mike Snitzer
2024-08-27 21:25 ` NeilBrown
2024-08-23 18:14 ` [PATCH v13 10/19] nfsd: add localio support Mike Snitzer
2024-08-25 15:13 ` Chuck Lever
2024-08-26 0:53 ` NeilBrown
2024-08-26 20:03 ` Mike Snitzer
2024-08-23 18:14 ` [PATCH v13 11/19] nfsd: implement server support for NFS_LOCALIO_PROGRAM Mike Snitzer
2024-08-25 15:09 ` Chuck Lever
2024-08-23 18:14 ` [PATCH v13 12/19] nfs: pass struct nfsd_file to nfs_init_pgio and nfs_init_commit Mike Snitzer
2024-08-23 18:14 ` [PATCH v13 13/19] nfs: add localio support Mike Snitzer
2024-08-26 1:21 ` NeilBrown
2024-08-23 18:14 ` [PATCH v13 14/19] nfs: enable localio for non-pNFS IO Mike Snitzer
2024-08-23 18:14 ` [PATCH v13 15/19] pnfs/flexfiles: enable localio support Mike Snitzer
2024-08-26 1:39 ` NeilBrown
2024-08-26 15:38 ` Mike Snitzer
2024-08-27 21:27 ` NeilBrown
2024-08-23 18:14 ` [PATCH v13 16/19] nfs/localio: use dedicated workqueues for filesystem read and write Mike Snitzer
2024-08-23 18:14 ` [PATCH v13 17/19] nfs: implement client support for NFS_LOCALIO_PROGRAM Mike Snitzer
2024-08-23 18:14 ` [PATCH v13 18/19] nfs: add Documentation/filesystems/nfs/localio.rst Mike Snitzer
2024-08-23 18:14 ` [PATCH v13 19/19] nfs: add FAQ section to Documentation/filesystems/nfs/localio.rst Mike Snitzer
2024-08-26 1:56 ` NeilBrown
2024-08-26 14:16 ` Chuck Lever III
2024-08-26 14:50 ` Trond Myklebust
2024-08-27 21:49 ` NeilBrown
2024-08-27 22:24 ` Trond Myklebust
2024-08-27 23:41 ` NeilBrown
2024-08-28 0:08 ` Trond Myklebust
2024-08-28 4:26 ` Mike Snitzer
2024-08-25 15:46 ` [PATCH v13 00/19] nfs/nfsd: add support for localio Chuck Lever
2024-08-27 16:56 ` Mike Snitzer [this message]
2024-08-26 1:59 ` NeilBrown
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=Zs4FSgwOqbqt6JYJ@kernel.org \
--to=snitzer@kernel.org \
--cc=anna@kernel.org \
--cc=chuck.lever@oracle.com \
--cc=jlayton@kernel.org \
--cc=linux-fsdevel@vger.kernel.org \
--cc=linux-nfs@vger.kernel.org \
--cc=neilb@suse.de \
--cc=trondmy@hammerspace.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).