On May 7, 2013, at 5:02 PM, "J. Bruce Fields" <bfields@xxxxxxxxxxxx> wrote: > On Mon, May 06, 2013 at 06:33:48PM -0400, Chuck Lever wrote: >> >> On May 3, 2013, at 5:50 PM, Chuck Lever <chuck.lever@xxxxxxxxxx> wrote: >> >>> >>> On May 3, 2013, at 5:18 PM, "J. Bruce Fields" <bfields@xxxxxxxxxxxx> wrote: >>> >>>> On Fri, May 03, 2013 at 02:48:59PM -0400, Chuck Lever wrote: >>>>> We should always use krb5i if a GSS context can be established with >>>>> our machine cred. As I said before, SETCLIENTID and >>>>> GETATTR(fs_locations) really should use an integrity-protecting >>>>> security flavor no matter what flavor is in effect on the mount points >>>>> themselves. >>>> >>>> Can you give an example of a threat that could be avoided by this? >>>> >>>> My suspicion is that in most cases an attacker with the ability to >>>> subvert auth_sys could *also* DOS gssd, and hence force the fallback to >>>> auth_sys. >>>> >>>> krb5i plus a fallback to auth_sys on failure to authenticate doesn't >>>> sound to me much more secure than just auth_sys. >>> >>> Our current situation is that the first mount of a server determines the flavor to use for SETCLIENTID. So if that mount happens to be "sec=sys" the SETCLIENTID is done with AUTH_SYS no matter what the subsequent mounts request. >>> >>> That's just about as secure in many cases as falling back. >>> >>>> If we really want much security benefit from krb5i on state operations, >>>> I think we need to really *require* krb5i. >>>> >>>> So I'm inclined towards Jeff's solution: don't do this unless userspace >>>> somehow affirmatively states that it requires krb5i on state operations. >>> >>> This would have to be on a per-server basis. Where would an admin specify such an option? I don't believe either a mount option (too fine) or a module parameter (too coarse) is appropriate. >>> >>>> I agree that we should default to this when we can. But the way to move >>>> towards that default is then to get distributions to turn on the new >>>> module parm (or whatever it is) by default. As they do so, they can >>>> also ensure that e.g. gssd is started. >>> >>> gssd is not all that's required. A keytab must be provisioned on the client and server for it to work, and that's the main issue I'm trying to address: We need "sec=krb5" mounts to work when the client has no GSS machine credential. >>> >>> And I think we already have a problem with gssd not picking up kernel requests quickly, as Trond pointed out. >>> >>> I don't feel like any of this is new, or that any of this is a strong reason to revert. But it could be a reason to move forward from here. >>> >>> Does gssd distinguish between: >>> >>> - no local keytab >>> >>> - no local support for GSS >>> >>> - server doesn't grok GSS >>> >>> - some network problem occurred >>> >>> Can it communicate that distinction to the kernel? What if we fall back only in the "no keytab" and "client's kernel has no GSS support" cases? In the "server doesn't grok" case, do not fall back if "sec=krb5*" is specified on the mount point? "A network problem occurred" is an "always fail" case. >> >> After some thought, here's an algorithm for selecting a flavor to use for state management operations: >> >> Start with krb5i. >> >> - If a GSS flavor is specified on the mount point, and if >> there is no local keytab, fall back to AUTH_SYS; otherwise >> if any other issue occurs, fail immediately. This >> modification should address your security concern. >> >> - If a non-GSS flavor is specified on the mount point, or no >> flavor is specified, and there is any problem with krb5i, >> fall back to AUTH_SYS. This is the current 3.10 behavior, >> and assumes there is a solution to Jeff's 15 second upcall >> delay issue. > > I'm having a hard time thinking of one.... Apparently not... :-) > I suppose if gssd is running then it should always hold open the parent > (rpc_pipefs/nfs) directory. So if that isn't open it might be safe to > assume we can fail immediately. I can look into that, if no-one beats me to it. I'm pretty slammed this week, though. Note also: If rpcauth_gss.ko isn't loaded, the rpcauth_create() call should fail immediately if the kernel cannot load that module. Why not make that module unloadable if gssd isn't running? > Right now for most people the effect of an upgrade to 3.10 is a new 15 > second delay on mount? (I'm assuming distributions default to not > running gssd.) Seems painful. The effect is that people who don't run gssd will see a 15 second delay the first time they mount a server with NFSv4. Subsequent mounts of that server should not see that delay because the SETCLIENTID has already been done. But 3.10 is not final. We have an opportunity to fix this now. So making claims about how painful this is right now is academic. Are you guys just trying to give me a hard time about this? Because it's not helping anybody. Nobody is saying this is something that should not be fixed as quickly as we can. -- Chuck Lever chuck[dot]lever[at]oracle[dot]com -- To unsubscribe from this list: send the line "unsubscribe linux-nfs" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html