ANN: DNS resolver changes in yakkety
Martin Pitt
martin.pitt at ubuntu.com
Wed Jun 1 07:37:51 UTC 2016
Stéphane Graber [2016-05-31 17:26 -0400]:
> So yes, the random transaction ID sure helps, so long as it's actually
> random and so long as you get a DNS reply reasonably quickly.
It's reading from /dev/urandom, so pretty much "as random as you can
get".
> I think your estimate of a minute isn't anywhere near accurate. One
> could pretty easily pre-generate all 32768 packets in pcap format, just
> replace the source address and port once known and then inject the whole
> pcap onto the network much much faster than that.
No, that doesn't work, as I explained in my other reply. You only have
one shot and then have to wait for the cached entry to time out until
you get another one. I. e. a chance of 1/65536 in say half an hour,
which is much worse than having a chance every few minutes or seconds
if the client does not cache DNS queries.
> > > 1- a privacy issue. It is trivial for a local user to probe if a site was
> > > visited by another local user.
> >
> > I assume by looking at the time that it takes to get a response?
>
> stgraber at dakara:~$ dig www.ubuntu.com @172.17.20.30
> www.ubuntu.com. 600 IN A 91.189.89.118
>
> stgraber at dakara:~$ dig www.ubuntu.com @127.0.0.1
> www.ubuntu.com. 594 IN A 91.189.89.118
>
>
> The first query shows you the TTL for the record from the recursive
> server used by the local resolver, here we see it's 600 seconds, the
> second request hits the local cache which returns a TTL of 594 seconds.
> Meaning that the DNS record was accessed by someone on the machine
> within the last 6 seconds.
>
> Do that with some sensitive website and you can know when someone on the
> machine accessed it.
>
> Note that the above wasn't done through resolved.
Exactly :-) So this is unrelated as dig doesn't use nsswitch and thus
isn't affected by how we configure resolved.
However, you can still look at the time it takes. When I try this with
a site that I haven't called in ages:
$ time host www.cnn.com
www.cnn.com is an alias for turner.map.fastly.net.
turner.map.fastly.net has address 185.31.19.73
real 0m0.170s
$ time host www.cnn.com
www.cnn.com is an alias for turner.map.fastly.net.
turner.map.fastly.net has address 185.31.19.73
real 0m0.155s
$ time host www.cnn.com
www.cnn.com is an alias for turner.map.fastly.net.
turner.map.fastly.net has address 185.31.19.73
real 0m0.155s
So there is a measurable time difference when a lookup happens (the
first time) and when it's cached (the two others).
However: as you demonstrated with dig, you don't necessarily need to
get this information from the local resolver -- you can look at the
TTL at the real DNS servers in /etc/resolv.conf with dig.
So, the current status is:
1) I'm not convinced yet [1] that disabling caching helps against
injecting false responses. resolved implements enough of
https://tools.ietf.org/html/rfc5452 to make local attacks
impossible, and remote attacks actually harder than without a
cache.
2) I acknowledge the timing difference between recently visited and
unvisited addresses, but you can get the same information from
your real DNS server with more precision.
Thanks!
Martin
P.S. This is a really enjoyable and good discussion, thank you!
[1] Note, I don't claim "it's impossible", I'm just saying that the
current arguments aren't sufficient.
--
Martin Pitt | http://www.piware.de
Ubuntu Developer (www.ubuntu.com) | Debian Developer (www.debian.org)
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 819 bytes
Desc: not available
URL: <https://lists.ubuntu.com/archives/ubuntu-devel/attachments/20160601/6acf93d5/attachment.pgp>
More information about the ubuntu-devel
mailing list