On Wed, 2019-01-23 at 18:10 +0000, Trond Myklebust wrote: > Hi, > > I'd like to propose an LSF/MM discussion around the topic of > containers and distributed filesystems. > > The background is that we have a number of decisions to make around > dealing with namespaces when the filesystem is distributed. > > On the one hand, there is the issue of which user namespace we should > be using when putting uids/gids on the wire, or when translating into > alternative identities (user/group name, cifs SIDs,...). There are > two main competing proposals: the first proposal is to select the > user namespace of the process that mounted the distributed > filesystem. The second proposal is to (continue to) use the user > namespace pointed to by init_nsproxy. It seems that whichever choice > we make, we probably want to ensure that all the major distributed > filesystems (AFS, CIFS, NFS) have consistent handling of these > situations. I don't think there's much disagreement among container people: most would agree the uids on the wire should match the uids in the container. If you're running your remote fs via fuse in an unprivileged container, you have no access to the kuid/kgid anyway, so it's the way you have to run. I think the latter comes about because most of the container implementations still have difficulty consuming the user namespace, so most run without it (where kuid = uid) or mis-implement it, which is where you might get the mismatch. Is there an actual use case where you'd want to see the kuid at the remote end, bearing in mind that when user namespaces are properly set up kuid is often the product of internal subuid mapping. > Another issue arises around the question of identifying containers > when they are migrated. At least the NFSv4 client needs to be able to > send a unique identifier that is preserved across container > migration. The uts_namespace is typically insufficient for this > purpose, since most containers don't bother to set a unique hostname. We did have a discussion in plumbers about the container ID, but I'm not sure it reached a useful conclusion for you (video, I'm afraid): https://linuxplumbersconf.org/event/2/contributions/215/ > Finally, there is an issue that may be unique to NFS (in which case > I'd be happy to see it as a hallway discussion or a BoF session) > around preserving file state across container migrations. If by file state, you mean the internal kernel struct file state, doesn't CRIU already do that? or do you mean some other state? James