issue with MIT KDC and LDAP DS

Simo Sorce ssorce at redhat.com
Fri May 22 18:35:16 EDT 2009


On Fri, 2009-05-22 at 18:04 -0400, Jeffrey Hutzelman wrote:
> --On Friday, May 22, 2009 03:57:58 PM -0500 Will Fiveash 
> <William.Fiveash at Sun.COM> wrote:
> 
> > I'm looking for input regarding my changing the following behavior of
> > the krb5kdc and kadmind.  Currently, when a KDC is configured to use the
> > LDAP KDB plugin and krbr5kdc is started prior to the DS being on-line,
> > the krb5kdc exits immediately with an error.  I want to change this
> > behavior so krb5kdc (and kadmind) stays up even when the DS is off-line.
> > The idea is that LDAP bind errors such as LDAP_SERVER_DOWN and
> > LDAP_CONNECT_ERROR would be treated as non-fatal in
> > krb5_ldap_initialize().  krb5kdc would daemonize itself as it normally
> > does but if there were no DS server connections up would try to bind
> > with a DS when it receives krb requests.  If it is unable to bind it
> > would send an error response to the *_REQ requester and wait for the
> > next request whereupon it would try to bind again.
> >
> > The kadmind would behave similarly, sending back errors until it was
> > able to bind to the DS.
> >
> > Thoughts?
> 
> This sounds good in general, but I'd make a couple of changes...
> 
> - Instead of attempting a bind when the KDC receives a request and
>   doesn't currently have a connection, it should periodically try
>   in the background, and simply fail immediately if it gets a request
>   and there is no connection.  Otherwise, the KDC may take a long
>   time to process each request, causing it to take much longer to
>   process requests than clients are willing to wait, and falling
>   behind (i.e starting to process a request when it is already very
>   old).
> 
> - Instead of returning an error when there is no connection, the KDC
>   should probably just drop the request on the floor.  This doesn't
>   sound very friendly, but there is no other way to signal to clients
>   that they should try another KDC.

Totally agree on both comments, and I'd love to see this implemented.

Simo.

-- 
Simo Sorce * Red Hat, Inc * New York




More information about the krbdev mailing list