There are two types of best practices for operators of authoritative servers for Second Level Domains (SLDs) that do not operate critical zones: DNS security, and DNS availability and resilience. In addition to these two categories specific to the core DNS, all operators must pay careful attention to practices related to hardening their core system security.
DNS Security: These best practices are aimed at improving the security of your DNS service itself, helping prevent users from being served malicious data, and lowering the chances of data corruption going unnoticed.
Practice 1: Authoritative zones MUST be DNSSEC signed and best practices for key management MUST be followed.
Rationale: Signing a zone using DNSSEC authenticates the origin of the data and protects the data’s integrity. DNSSEC is built on top of public key cryptography. Zone owners use a private key to create digital signatures of the DNS data, and publish it in the zone alongside the data. Also published in the zone is the public key used by DNSSEC-enabled resolvers to verify (or validate) the signatures. If the signature matches the data published, then the data hasn’t been corrupted or tampered with on its path from the authoritative servers for the zone, through one or more resolvers, to the final client. The keys used to sign the data are in turn signed by the operators of the parent zone, all the way to the root of the DNS. ccTLD operators should see the ICANN DNSSEC guidebook for ccTLDs for more information. |
Practice 2: Access to zone transfer between authoritative servers MUST be limited. Configure ACLs and TSIG in the DNS Authoritative software package to restrict zone transfers to secondary servers.
Rationale: Third parties who are involved in providing secondary service for a zone have no reason to request the entire content of a zone. While DNS data is public, there are some security risks associated with unauthorized parties having access to an entire zone’s content. Also, large zones can cause significant amounts of traffic if zone transfers are repeated multiple times. |
Practice 3: Zone file integrity MUST be controlled to avoid unexpected modifications (malicious or accidental).
Rationale: In the event of data corruption or suspected security breach leading to unauthorized modification of DNS data, a mechanism should be implemented to detect such changes and when they occurred. |
DNS Availability and Resilience: These best practices aim to improve the robustness, resilience, and stability of your DNS infrastructure. Some of the recommendations can be implemented with minimal changes or additions to your infrastructure.
Practice 4: Authoritative and recursive DNS service MUST NOT coexist on the same DNS server. In the context of authoritative servers, this means you MUST disable recursive DNS resolution on servers configured to serve authoritative DNS data (if the software allows running both authoritative and recursive at the same time).
Rationale: DNS software packages such as ISC BIND can be configured to function as authoritative and recursive resolution on the same installation. Historically, this was to avoid the cost and overhead of two separate servers, particularly before virtualization was common. This is still the default behavior in most Windows DNS deployments as well. Clients in Active Directory enabled environments are typically configured to send recursive DNS lookups to DNS servers that by default serve a copy of the organization’s DNS zone. Queries for other domain names are resolved as usual (either directly, or by forwarding queries to an external server). |
Practice 5: At least two distinct nameservers MUST be used for any given zone with diversity in operational and geographical practices in mind.
- All the authoritative servers for a given zone MUST NOT be placed on the same subnet
- All the authoritative servers for a given zone MUST be in different physical locations (not the same rack, room, city or country).
Rationale: If the equipment, network or location where your DNS servers are located suffers an outage (software, hardware, network, etc.), this shouldn’t affect the ability for the rest of the Internet to look up data in the affected domains, even if part or all of the servers and services referenced in the affected domains may be unreachable. Some software may behave in unpredictable ways or cause unnecessary timeouts as they attempt to look up information from unreachable DNS servers. Also, solutions using load balancers aren’t recommended: in case of a failure of the load balancing system, all DNS services placed behind it become unavailable simultaneously. It may be tempting to increase reliability using a load balancer in front of multiple servers, but this usually isn’t practical because it doesn’t easily allow for geographical diversity, introduces complexity, and risks overloading stateful systems in case of D/DoS type traffic patterns. |
Practice 6: Monitoring of the services, servers, and network equipment that make up your DNS infrastructure MUST be implemented.
Rationale: Monitoring of your DNS service is critical to ensure that it is available to users and customers. This can be achieved through local monitoring (hosted on premises) or a remote location, and either managed by yourself or a third party (outsourced/cloud based). |