Proposal for using NAPTR/URI records
Simo Sorce
simo at redhat.com
Fri Feb 27 11:52:43 EST 2015
On Fri, 2015-02-27 at 10:38 -0600, Nico Williams wrote:
> On Fri, Feb 27, 2015 at 02:58:33PM +0100, Petr Spacek wrote:
> > On 26.2.2015 20:20, Nico Williams wrote:
> > > On Thu, Feb 26, 2015 at 06:02:11PM +0100, Petr Spacek wrote:
> > >> I forgot to comment on this:
> > >> QTYPE=ANY is unreliable because admins are disabling it in hope that
> > >> it will mitigate DNS-amplified DDoS attacks. (It would be better to
> > >> implement source-address filtering but what you can do ...)
> > >
> > > I see, and it's probably a good idea, but in a DNSSEC world this is
> > > equivalent to timing out, no?
> >
> > There are some 'legal' options how to avoid answering QTYPE=ANY queries:
> > Either send REFUSED to the client or set TC=1 in the answer and force client
> > to re-try over TCP.
>
> REFUSED and TC would do if they were the only _and_ uncommon failure
> scenarios. More below.
>
> > Anyway, Firefox folks started an interesting (and possibly unintentional)
> > experiment with ANY queries so we can watch how it works in practice.
> > See https://bugzilla.mozilla.org/show_bug.cgi?id=1093983
>
> See also:
>
> a) the thread starting at
> https://lists.dns-oarc.net/pipermail/dns-operations/2015-February/012886.html
>
> and
> b) the linked report:
> https://bugzilla.mozilla.org/show_bug.cgi?id=1137628
>
> RFC1035 doesn't say much about QTYPE=* queries (it says a lot more about
> the arguably useless QCLASS=* queries).
>
> These two reports at bugzilla.mozilla.org will be worth watching over
> the next few weeks, but my guess is that we're not likely to get much
> more data out of them, and the we're likely to see the code for type=ANY
> queries dropped.
>
> I'm not sure now what to suggest as to ways forward, but I'll note that
> KDC-over-HTTP protocols are not widely needed yet, and where they are,
> local configuration can be expected to work for the time being.
>
> We should list the constraints:
>
> - A very strong desire to keep DNS queries to a minimum.
>
> - KDC-over-HTTP protocols require all that a URI delivers: a scheme,
> authority, local part, maybe even queries (though not fragments).
>
> - Infeasibility of mapping SRV RRs to URIs: SRV RRs do not express
> scheme nor local part. It's not entirely infeasible, but it's quite
> distasteful (it would require either hardcoding of the local part or
> additional discovery of it) and will elicit objections.
>
> Using SRV RRs would require using a different domainname than
> currently used for the other KDC SRV RRs anyways, which increases the
> number of DNS queries needed.
>
> - Lack of universal async DNS query libraries.
>
> This means we can't just do concurrent queries (nor can we do a query
> for the parent domainname then two concurrent queries for the
> domainname of interest).
>
> We probably have to assume nothing better than the traditional ISC
> resolver found in all the BSDs, glibc, Solaris/Illumos, and so on.
>
> I think this adds up to: multiple DNS queries, with some local
> configuration will be needed to decide on a DNS query order.
>
> And we've not even begun to discuss any concept of client-side HTTP
> proxies that might need to be different for KDC exchanges than for other
> uses (let's avoid this).
>
> Nico
My preference would be to implement the URI protocol, but not enable
querying for it by default in 1.14, add a tunable in [libdefaults ]
called something like dns_uri_lookup_kdc = false|true|only and set it to
false by default, change it to true later on ? (let downstream change
the default if they so desire)
Simo.
--
Simo Sorce * Red Hat, Inc * New York
More information about the krbdev
mailing list