hello-dns/optional.md
2018-10-17 06:42:57 +02:00

69 lines
3.3 KiB
Markdown

<meta charset="utf-8" emacsmode="-*- markdown -*-">
**A warm welcome to DNS**
# EDNS, Dynamic Updates, TSIG, DNAME, DNS Cookies & more
So far we've focussed on the simplest possible form of DNS that is
interoperable with today's internet. Over the past 3 decades however, a lot
has been added to DNS.
Items relevant for authoritative servers and resolvers:
* EDNS: Extra fields carried in the additional section of a DNS message,
including arbitrary options. The main use of EDNS today is specifying a
larger supported UDP packet size, indicating DNSSEC support and carrying
Client Subnet information. Defined in [RFC
6891](https://tools.ietf.org/html/rfc6891).
* EDNS Client Subnet: Convey (part) of client addresses to authoritative
resolvers. Defined in [RFC 7871](https://tools.ietf.org/html/rfc7871).
* DNAME: Domain redirection [RFC 6672](https://tools.ietf.org/html/rfc6672)
* DNS Cookies: Lightweight transaction security mechanism [RFC 7873](https://tools.ietf.org/html/rfc7873)
Relevant for authoritative servers:
* Dynamic Updates: Transmitting changes to zones to master servers. Mostly
used by DHCP servers to publish names of hosts. Defined in [RFC
2136](https://tools.ietf.org/html/rfc2136)
* TSIG: Secret Key Transaction Authentication for DNS. A way to sign DNS
messages or a list of DNS messages with a secret key. Used to authenticate
AXFR requests and to guarantee zone integrity during AXFR. Defined in
[RFC 2845](https://tools.ietf.org/html/rfc2845).
## Extended DNS (EDNS or EDNS(0))
EDNS is very much an enabling technology and it can't really be regarded as
optional anymore. It enables DNSSEC, DNS Cookies, EDNS Client Subnet as
well as larger UDP packets. It also expands on the 4-bit RCODE field of
un-extended DNS.
The EDNS content is attached to a pseudo-record called OPT in the additional
section of a message and an answer.
The following EDNS fields are always present:
* Requestor's maximum UDP payload size
* Extended RCODE (an additional 8 bits)
* EDNS Version
* DNSSEC OK bit (which indicates DNSSEC support from the requestor)
* Yet another field called 'Z' which must be zero
In order to save size, the EDNS 'OPT' pseudo-record reuses existing resource
record fields to store its data. For example, the UDP payload size is stored
in the 16 bit class field, and the extended RCODE, version and flags hang
out in the TTL field.
Just like regular record types, the OPT pseudo-record can carry a payload.
This consists of 0 or more 'Type Length Value' tuples. The following types
are currently in common use, or will soon be:
* NSID (3): Return the 'nameserver identifier' [RFC
5001](https://tools.ietf.org/html/rfc5001)
* EDNS Client Subnet (8): Convey part of client subnet [RFC 6891](https://tools.ietf.org/html/rfc2671).
* Cookie (10): Lightweight transaction security [RFC 7873](https://tools.ietf.org/html/rfc7873)
[RFC 7871](https://tools.ietf.org/html/rfc7871) is a concise specification
that is completely applicable to 2018 DNS. Its implementation is highly
recommended.
...
<!-- Markdeep: --><style class="fallback">body{visibility:hidden;white-space:pre;font-family:monospace}</style><script src="ext/markdeep.min.js"></script><script>window.alreadyProcessedMarkdeep||(document.body.style.visibility="visible")</script>