Line 110: | Line 110: | ||
==== Docker & iptables(8) ==== | ==== Docker & iptables(8) ==== | ||
Docker server creates a virtual bridge interface - '''docker0''' - as a link between containers and the host. When docker starts a container, it creates two network interfaces each bound to the '''docker0''' bridge. At one end of the 'docker0' bridge is the container's '''eth0''' interface and at the other end is '''veth*''' interface on the host. Ie. all network traffic from containers passes through the '''docker0''' bridge. [https://docs.docker.com/articles/networking/ -> https://docs.docker.com/articles/networking/] | Docker server creates a virtual bridge interface - '''docker0''' - as a link between containers and the host. When docker starts a container, it creates two network interfaces each bound to the '''docker0''' bridge. At one end of the 'docker0' bridge is the container's '''eth0''' interface and at the other end is '''veth*''' interface on the host. Ie. all network traffic from containers passes through the '''docker0''' bridge. [https://docs.docker.com/articles/networking/ -> https://docs.docker.com/articles/networking/] | ||
'''Currently Docker would work with the local DNS resolver, but would not use it.''' When /etc/resolv.conf contains the localhost address, Docker ignores it and rather puts the Google's DNS resolvers (8.8.8.8 and 8.8.4.4) into the containers's resolv.conf. | |||
For container applications to take advantage of the DNSSEC resolver on the host, we need to divert DNS traffic from '''docker0''' interface to the local '''lo''' interface on the host. This can be accomplished by following these steps: | For container applications to take advantage of the DNSSEC resolver on the host, we need to divert DNS traffic from '''docker0''' interface to the local '''lo''' interface on the host. This can be accomplished by following these steps: | ||
Line 125: | Line 127: | ||
$ iptables -t nat -I PREROUTING -p UDP -s 172.17.0.0/16 --dport 53 -i docker0 -j DNAT --to-destination 127.0.0.1:53 | $ iptables -t nat -I PREROUTING -p UDP -s 172.17.0.0/16 --dport 53 -i docker0 -j DNAT --to-destination 127.0.0.1:53 | ||
The progess and changes are tracked in the [https://bugzilla.redhat.com/show_bug.cgi?id=1258350 Bug #1258350], which contains the link to upstream issue. | |||
=== Hot-Spot detection === | === Hot-Spot detection === |
Revision as of 10:15, 30 November 2015
Default Local DNS Resolver
Summary
Plain DNS protocol is insecure and therefore vulnerable from various attacks (e.g. cache poisoning). A client can never be sure that there is no man-in-the-middle, if it does not do the DNSSEC validation locally.
We want to have Unbound server installed and running on localhost by default on Fedora systems. Where necessary, have also dnssec-trigger installed and running by default. Unbound and dnssec-trigger will be properly integrated with the default network configuration manager (e.g. NetworkManager for Fedora Server and Workstation) and with the graphical user interface (especially GNOME). The localhost address will be the only record in /etc/resolv.conf and no other software except dnssec-trigger will be allowed to change its content.
Owner
- Name: P J P | Pavel Šimerda | Tomas Hozza | Petr Špaček
- Email: P J P <pjp@fedoraproject.org> | Pavlix <pavlix@pavlix.net> | Tomas Hozza <thozza@redhat.com> | Petr Špaček <pspacek@redhat.com>
- Release notes owner:
Current status
- Targeted release: Fedora 24
- Last updated: 2015-11-19
- Tracker bug: #1182488
- Progress is tracked in Taiga: http://taiga.cloud.fedoraproject.org/project/thozza-default-dns-resolver
Detailed Description
Plain DNS protocol is insecure and therefore vulnerable from various attacks (e.g. cache poisoning). DNSSEC is a DNS extension which enabled the client to verify the DNS query response and make sure there is no attacker to spoof some records. A user connected to network usually receives a set of resolvers from DHCP, which should be used for name resolution. These resolvers may also do the DNSSEC validation. However a client can never be sure that there is no man-in-the-middle, if it does not do the DNSSEC validation locally. Purpose of this Fedora change is to have a validating DNS resolver installed on Fedora systems by default. This includes necessary discussions, coordination and integration with other components installed on Fedora by default.
There are growing instances of discussions and debates about the need for a trusted local validating DNS resolver. There are multiple reasons for having such a resolver, most importantly security and usability. Security and protection of user's privacy becomes paramount with the backdrop of the increasingly snooping governments and service providers world wide.
People use Fedora on portable/mobile devices which are connected to diverse networks as and when required. The automatic DNS configurations provided by these networks are never trustworthy for DNSSEC validation, as currently there is no way to establish such trust.
Apart from trust, these name servers are often known to be flaky and unreliable which only adds to the overall bad and at times even frustrating user experience. In such a situation, having a trusted local validating DNS resolver not only makes sense but is, in fact, badly needed. It has become a need of the hour. (See: [1], [2], [3])
All DNS literature strongly recommends it and amongst all discussions and debates about the issues involved in establishing such trust, it is unanimously agreed upon and accepted that having a trusted local DNS resolver is the best solution possible. It will simplify and facilitate a lot of other design decisions and application development in the future. (See: [1], [2], [3])
---
[1] https://www.ietf.org/mail-archive/web/dane/current/msg06469.html
[2] https://www.ietf.org/mail-archive/web/dane/current/msg06658.html
[3] https://lists.fedoraproject.org/pipermail/devel/2014-April/197755.html
Decisions made based on discussion between change owners, Gnome and NetworkManager developers
- dnssec-trigger will not do any Hot-Spot detection
- dnssec-trigger panel will not be installed by default on Fedora Workstation
- if dnssec-trigger determines that the connection provided resolvers are not usable for DNSSEC validation, it is not able to do the full recursion and it is not able to tunnel the communication over SSL, then it automatically switches to the "non-validating" (which is basically the actual state in Fedora <=23) mode. This will be the default behavior - but configurable. The insecure mode will be implemented using one of these approaches:
- resolv.conf's content will be modified to contain connection provided resolvers
- Unbound will not do the validation for the necessary time.
- Hot-Spot detection is done only by NetworkManager
- NetworkManager should be able to notify services (dnssec-trigger) via dispatcher or some other means on any connectivity state change (This part will be sorted out with NM developers)
- Hot-Spot login is handled by Gnome
- Gnome uses the connection provided DNS resolvers instead of the ones in resolv.conf for Hot-Spot login purposes.
Benefit to Fedora
What is the benefit to the platform?
Fedora distribution has been the industry leader when it comes to shipping the best and latest software to its users. In many cases Fedora has been the trend setter in accepting new technologies like Systemd. With having a trusted local validating DNS resolver, Fedora will not only provide greater security and usability to its users, but will also take an important step towards the secure by default computing future, wherein users do not have to worry about privacy, security and trust.
Specific benefits:
- Improved security when using Internet services, thanks to local DNSSEC validation
- User and applications will be able to trust the AD bit set in the DNS answer.
- Existence of system-wide DNS cache (in Unbound server) will speed up the resolution of frequent domain names and in general will save network traffic.
- Have a real split-DNS configuration - e.g. forward only specific DNS queries to the VPN-provided resolvers.
Scope
- Proposal owners: Proposal owners shall have to
- define the syntax and semantics for new configuration parameters/files.
- properly document how to test and configure the new default setup
- persuade and coordinate with the other package owners to incorporate new changes/workflow in their applications.
- discuss with WGs in which products the change makes sense and what are the expectations of WGs for different Fedora products
- resolve interoperability issues for Docker and other containers use-cases
- Other developers: (especially NetworkManager and the likes)
- NetworkManager has to implement notifications on connectivity state changes
- Gnome Shell has to use the connection provided resolvers (fetched directly from NM) for Hot-Spot login purposes
- Ideally other developers and user should test their software and application in this setup and verify that it is working as expected
- Release engineering:
- Make sure that the necessary packages (dnssec-trigger, unbound) are part of the composes for the appropriate Fedora Products.
- Add services needed for the setup into the default presets (dnssec-triggerd.service)
- Policies and guidelines:
- Any software, including NetworkManager, will have to be configured to not tamper with the content of '/etc/resolv.conf' by default. The connection-provided resolver entries should be stored in a separate configuration file or in memory and accessible via some API.
Upgrade/compatibility impact
- Any packages directly modifying the content of /etc/resolv.conf will not be able to modify the content any more. The software should notify about the changes the default network configuration management software (e.g. NetworkManager), rather than do the changes directly.
- Any packages that use the system name resolution libraries should continue to work without any problems, as the name resolution library usually use the resolvers listed in '/etc/resolv.conf'.
Docker
Docker and other users of network namespaces, like systemd-nspawn, would break. When docker runs, it picks up the current '/etc/resolv.conf' and puts it in the container. But the container itself runs in a network namespace, so it gets its own loop-back device. This means 127.0.0.1:53 points to the container itself, not the host. So DNS resolving in the container will not work. -> https://lists.fedoraproject.org/pipermail/devel/2014-April/198706.html
Docker and containers could be able to use host's DNSSEC resolver via a dedicated interface and iptables(8) rules, though such configurations need to be investigated for their feasibility. Please see:
- https://github.com/docker/docker/issues/6388
- https://www.piratepad.ca/p/dnssec-requisites-configurations
Docker & iptables(8)
Docker server creates a virtual bridge interface - docker0 - as a link between containers and the host. When docker starts a container, it creates two network interfaces each bound to the docker0 bridge. At one end of the 'docker0' bridge is the container's eth0 interface and at the other end is veth* interface on the host. Ie. all network traffic from containers passes through the docker0 bridge. -> https://docs.docker.com/articles/networking/
Currently Docker would work with the local DNS resolver, but would not use it. When /etc/resolv.conf contains the localhost address, Docker ignores it and rather puts the Google's DNS resolvers (8.8.8.8 and 8.8.4.4) into the containers's resolv.conf.
For container applications to take advantage of the DNSSEC resolver on the host, we need to divert DNS traffic from docker0 interface to the local lo interface on the host. This can be accomplished by following these steps:
- Enable local lo routing via docker0 bridge interface. (it is off by default)
$ sysctl -w net.ipv4.conf.docker0.route_localnet=1
- Enable unbonud(8) server to accept requests from 172.17.0.0/16 docker sub-network.
$ vi /etc/unbound/unbound.conf -> access-control: 172.17.0.0/16 allow
- Use iptables(8) destination nat(DNAT) feature to divert DNS traffic from docker0 to lo interface
$ iptables -t nat -I PREROUTING -p UDP -s 172.17.0.0/16 --dport 53 -i docker0 -j DNAT --to-destination 127.0.0.1:53
The progess and changes are tracked in the Bug #1258350, which contains the link to upstream issue.
Hot-Spot detection
Based on previous discussion with GNOME and NetworkManager developers we agreed, that NetworkManager will be the only one doing the Hot-Spot detection and that the Hot-Spot detection functionality in dnssec-trigger will be turned off by default (until network connectivity state change notifications are implemented in NM, only in Fedora Workstation).
Hot-Spot login
Based on previous discussion with GNOME developers, on Fedora Workstation, the Hot-Spot login is handled only by Gnome Shell and the Hot-Spot login functionality in dnssec-trigger is disabled.
dnssec-trigger panel
dnssec-trigger panel is not installed by default any more. For spins / products that don't have their own way of handling the Hot-Spot login, the dnssec-trigger panel should be added to the kickstart / compose.
How To Test
Expectations
Ideally everything should work as usual, out of the box. Responses for DNSSEC-protected domains will be validated automatically. In case the validation fails for DNSSEC-protected domain (e.g. due to misconfiguration or some ongoing attack) it will stop working.
You can use http://dnsviz.net/ service to finding out if there is any problem with the domain. Site http://www.dnssec-failed.org/ has intentionally invalid DNSSEC signatures to simulate an attack. The site should not be reachable if your configuration is correct.
How to get Unbound and dnssec-trigger running?
- Install dnssec-trigger daemon:
$ sudo dnf install dnssec-trigger
- If you use NetworkManager, configure it to use unbound. Add the following line into /etc/NetworkManager/NetworkManager.conf
dns=unbound
- Enable and start dnssec-trigger
$ sudo systemctl enable dnssec-triggerd.service
$ # disable and stop any existing DNS service, e.g., dnsmasq $ sudo systemctl start dnssec-triggerd.service
- Now it should just work. Please file a bug against dnssec-trigger component in Fedora if it doesn't.
- Validation failures should be recorded to the system log:
journalctl -f -l -u unbound.service unbound[1062]: [1062:0] info: validation failure <www.dnssec-failed.org. A IN >: no keys have a DS with algorithm RSASHA1 from 192.168.2.1 for key dnssec-failed.org. while building chain of trust
- See dnssec-trigger documentation for more details: http://www.nlnetlabs.nl/projects/dnssec-trigger/
User Experience
The change is something the user should ideally not even notice, however the experience may change for misconfigured domains.
Note: There's a DNSSEC/TLSA validator for Firefox (and some other browsers) developed by CZ.NIC Labs.
Note: We need to describe how automatic split DNS and DNSSEC affects the user when accessing local resources, resources not secured by DNSSEC and spoofed resources.
Dependencies
- Changes in Docker
- Changes in NetworkManager
- Changes in Gnome Shell
- Changes in default presets and products kickstarts
Contingency Plan
- Contingency mechanism: (What to do? Who will do it?)
- Release Engineers will have to reverse all the changes done to default presets and kickstart files, so that Unbound and dnssec-trigger won't be installed and enabled by default in Fedora Products.
- Contingency deadline: Beta freeze.
- Blocks release? - No
- Blocks product? product - No
Documentation
For more information on name resolution, DNS and DNSSEC, please check:
- Networking/NameResolution
- Networking/NameResolution/DNS
- Networking/NameResolution/DNSSEC
- Networking/NameResolution/DNSSEC/Design