69 lines
3.3 KiB
Markdown
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 however.
|
|
|
|
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/rfc2671).
|
|
* 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/rfc2136).
|
|
|
|
|
|
## 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>
|