Bv9ARM.ch09.html revision e21a6f5ec65fad1c18f6723f5495e55bcd15a53d
306763c67bb99228487345b32ab8c5c6cd41f23cChristian Maeder<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
306763c67bb99228487345b32ab8c5c6cd41f23cChristian Maeder<!--
306763c67bb99228487345b32ab8c5c6cd41f23cChristian Maeder - Copyright (C) 2000-2015 Internet Systems Consortium, Inc. ("ISC")
306763c67bb99228487345b32ab8c5c6cd41f23cChristian Maeder -
306763c67bb99228487345b32ab8c5c6cd41f23cChristian Maeder - This Source Code Form is subject to the terms of the Mozilla Public
306763c67bb99228487345b32ab8c5c6cd41f23cChristian Maeder - License, v. 2.0. If a copy of the MPL was not distributed with this
306763c67bb99228487345b32ab8c5c6cd41f23cChristian Maeder - file, You can obtain one at http://mozilla.org/MPL/2.0/.
306763c67bb99228487345b32ab8c5c6cd41f23cChristian Maeder-->
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder<html lang="en">
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder<head>
679d3f541f7a9ede4079e045f7758873bb901872Till Mossakowski<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
679d3f541f7a9ede4079e045f7758873bb901872Till Mossakowski<title>Appendix�A.�Release Notes</title>
306763c67bb99228487345b32ab8c5c6cd41f23cChristian Maeder<meta name="generator" content="DocBook XSL Stylesheets V1.78.1">
306763c67bb99228487345b32ab8c5c6cd41f23cChristian Maeder<link rel="home" href="Bv9ARM.html" title="BIND 9 Administrator Reference Manual">
679d3f541f7a9ede4079e045f7758873bb901872Till Mossakowski<link rel="up" href="Bv9ARM.html" title="BIND 9 Administrator Reference Manual">
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder<link rel="prev" href="Bv9ARM.ch08.html" title="Chapter�8.�Troubleshooting">
d21dd452cd68abade683103a5c0cfe6d02c5f17bTill Mossakowski<link rel="next" href="Bv9ARM.ch10.html" title="Appendix�B.�A Brief History of the DNS and BIND">
d21dd452cd68abade683103a5c0cfe6d02c5f17bTill Mossakowski</head>
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder<body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF">
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder<div class="navheader">
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder<table width="100%" summary="Navigation header">
f0e85ee7e4accfc01f46aa0363acc59fcd248e8aTill Mossakowski<tr><th colspan="3" align="center">Appendix�A.�Release Notes</th></tr>
f69658e57cba7ecb37c0d84181f4c563215c2534Till Mossakowski<tr>
ba904a15082557e939db689fcfba0c68c9a4f740Christian Maeder<td width="20%" align="left">
ba904a15082557e939db689fcfba0c68c9a4f740Christian Maeder<a accesskey="p" href="Bv9ARM.ch08.html">Prev</a>�</td>
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder<th width="60%" align="center">�</th>
ba904a15082557e939db689fcfba0c68c9a4f740Christian Maeder<td width="20%" align="right">�<a accesskey="n" href="Bv9ARM.ch10.html">Next</a>
ba904a15082557e939db689fcfba0c68c9a4f740Christian Maeder</td>
d410c66e2c3e16d75ef1066b501a539b08682ac3Maciek Makowski</tr>
ba904a15082557e939db689fcfba0c68c9a4f740Christian Maeder</table>
ba904a15082557e939db689fcfba0c68c9a4f740Christian Maeder<hr>
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski</div>
ba904a15082557e939db689fcfba0c68c9a4f740Christian Maeder<div class="appendix">
ba904a15082557e939db689fcfba0c68c9a4f740Christian Maeder<div class="titlepage"><div><div><h1 class="title">
58b671de3fe578346fef9642ffa3c5a0a0edb3cbTill Mossakowski<a name="Bv9ARM.ch09"></a>Release Notes</h1></div></div></div>
56cd0da55d058b262b1626ddcd78db6bd9a90551Christian Maeder<div class="toc">
ba904a15082557e939db689fcfba0c68c9a4f740Christian Maeder<p><b>Table of Contents</b></p>
ba904a15082557e939db689fcfba0c68c9a4f740Christian Maeder<dl class="toc">
c616e681da8c052b62e14247fea522da099ac0e4Christian Maeder<dt><span class="section"><a href="Bv9ARM.ch09.html#id-1.10.2">Release Notes for BIND Version 9.11.0rc3</a></span></dt>
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski<dd><dl>
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski<dt><span class="section"><a href="Bv9ARM.ch09.html#relnotes_intro">Introduction</a></span></dt>
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski<dt><span class="section"><a href="Bv9ARM.ch09.html#relnotes_download">Download</a></span></dt>
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski<dt><span class="section"><a href="Bv9ARM.ch09.html#relnotes_license">License Change</a></span></dt>
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski<dt><span class="section"><a href="Bv9ARM.ch09.html#relnotes_security">Security Fixes</a></span></dt>
a7f97f28aa8227408d4008e0b12a7bd925ef51feKlaus Luettich<dt><span class="section"><a href="Bv9ARM.ch09.html#relnotes_features">New Features</a></span></dt>
b0294d73dcefc502ddaa13e18b46103a5916971fTill Mossakowski<dt><span class="section"><a href="Bv9ARM.ch09.html#relnotes_changes">Feature Changes</a></span></dt>
b0294d73dcefc502ddaa13e18b46103a5916971fTill Mossakowski<dt><span class="section"><a href="Bv9ARM.ch09.html#relnotes_bugs">Bug Fixes</a></span></dt>
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski<dt><span class="section"><a href="Bv9ARM.ch09.html#end_of_life">End of Life</a></span></dt>
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski<dt><span class="section"><a href="Bv9ARM.ch09.html#relnotes_thanks">Thank You</a></span></dt>
58b671de3fe578346fef9642ffa3c5a0a0edb3cbTill Mossakowski</dl></dd>
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski</dl>
58b671de3fe578346fef9642ffa3c5a0a0edb3cbTill Mossakowski</div>
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski<div class="section">
a7f97f28aa8227408d4008e0b12a7bd925ef51feKlaus Luettich<div class="titlepage"><div><div><h2 class="title" style="clear: both">
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski<a name="id-1.10.2"></a>Release Notes for BIND Version 9.11.0rc3</h2></div></div></div>
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski<div class="section">
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski<div class="titlepage"><div><div><h3 class="title">
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski<a name="relnotes_intro"></a>Introduction</h3></div></div></div>
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski<p>
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski BIND 9.11.0 is a new feature release of BIND, still under development.
f0e85ee7e4accfc01f46aa0363acc59fcd248e8aTill Mossakowski This document summarizes new features and functional changes that
f0e85ee7e4accfc01f46aa0363acc59fcd248e8aTill Mossakowski have been introduced on this branch. With each development
f0e85ee7e4accfc01f46aa0363acc59fcd248e8aTill Mossakowski release leading up to the final BIND 9.11.0 release, this document
f0e85ee7e4accfc01f46aa0363acc59fcd248e8aTill Mossakowski will be updated with additional features added and bugs fixed.
f0e85ee7e4accfc01f46aa0363acc59fcd248e8aTill Mossakowski </p>
f0e85ee7e4accfc01f46aa0363acc59fcd248e8aTill Mossakowski</div>
f0e85ee7e4accfc01f46aa0363acc59fcd248e8aTill Mossakowski<div class="section">
f0e85ee7e4accfc01f46aa0363acc59fcd248e8aTill Mossakowski<div class="titlepage"><div><div><h3 class="title">
f0e85ee7e4accfc01f46aa0363acc59fcd248e8aTill Mossakowski<a name="relnotes_download"></a>Download</h3></div></div></div>
f0e85ee7e4accfc01f46aa0363acc59fcd248e8aTill Mossakowski<p>
f0e85ee7e4accfc01f46aa0363acc59fcd248e8aTill Mossakowski The latest versions of BIND 9 software can always be found at
f0e85ee7e4accfc01f46aa0363acc59fcd248e8aTill Mossakowski <a class="link" href="http://www.isc.org/downloads/" target="_top">http://www.isc.org/downloads/</a>.
f0e85ee7e4accfc01f46aa0363acc59fcd248e8aTill Mossakowski There you will find additional information about each release,
f0e85ee7e4accfc01f46aa0363acc59fcd248e8aTill Mossakowski source code, and pre-compiled versions for Microsoft Windows
f0e85ee7e4accfc01f46aa0363acc59fcd248e8aTill Mossakowski operating systems.
f0e85ee7e4accfc01f46aa0363acc59fcd248e8aTill Mossakowski </p>
f0e85ee7e4accfc01f46aa0363acc59fcd248e8aTill Mossakowski</div>
f0e85ee7e4accfc01f46aa0363acc59fcd248e8aTill Mossakowski<div class="section">
f0e85ee7e4accfc01f46aa0363acc59fcd248e8aTill Mossakowski<div class="titlepage"><div><div><h3 class="title">
f0e85ee7e4accfc01f46aa0363acc59fcd248e8aTill Mossakowski<a name="relnotes_license"></a>License Change</h3></div></div></div>
f0e85ee7e4accfc01f46aa0363acc59fcd248e8aTill Mossakowski<p>
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski With the release of BIND 9.11.0, ISC is changing the open
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski source license for BIND from the ISC license to the Mozilla
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski Public License (MPL 2.0). This change is effective from BIND
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski 9.11.0b1 onwards.
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski </p>
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski<p>
c616e681da8c052b62e14247fea522da099ac0e4Christian Maeder The MPL-2.0 license requires that if you make changes to
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder licensed software (e.g. BIND) and distribute them outside
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder your organization, that you publish those changes under that
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski same license. It does not require that you publish or disclose
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski anything other than the changes you made to our software.
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski </p>
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski<p>
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski This new requirement will not affect anyone who is using BIND
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski without redistributing it, nor anyone redistributing it without
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski changes, therefore this change will be without consequence
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski for most individuals and organizations who are using BIND.
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski </p>
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski<p>
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski Those unsure whether or not the license change affects their
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski use of BIND, or who wish to discuss how to comply with the
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski license may contact ISC at <a class="link" href="https://www.isc.org/mission/contact/" target="_top">
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski https://www.isc.org/mission/contact/</a>.
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski </p>
a7f97f28aa8227408d4008e0b12a7bd925ef51feKlaus Luettich</div>
a7f97f28aa8227408d4008e0b12a7bd925ef51feKlaus Luettich<div class="section">
a7f97f28aa8227408d4008e0b12a7bd925ef51feKlaus Luettich<div class="titlepage"><div><div><h3 class="title">
a7f97f28aa8227408d4008e0b12a7bd925ef51feKlaus Luettich<a name="relnotes_security"></a>Security Fixes</h3></div></div></div>
a7f97f28aa8227408d4008e0b12a7bd925ef51feKlaus Luettich<div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; ">
a7f97f28aa8227408d4008e0b12a7bd925ef51feKlaus Luettich<li class="listitem"><p>
d432d7594caca8c2587a3ca660c35865538464ceKlaus Luettich It was possible to trigger a assertion when rendering a
d432d7594caca8c2587a3ca660c35865538464ceKlaus Luettich message using a specially crafted request. This flaw is
d432d7594caca8c2587a3ca660c35865538464ceKlaus Luettich disclosed in CVE-2016-2776. [RT #43139]
d432d7594caca8c2587a3ca660c35865538464ceKlaus Luettich </p></li>
d432d7594caca8c2587a3ca660c35865538464ceKlaus Luettich<li class="listitem"><p>
d432d7594caca8c2587a3ca660c35865538464ceKlaus Luettich getrrsetbyname with a non absolute name could trigger an
d432d7594caca8c2587a3ca660c35865538464ceKlaus Luettich infinite recursion bug in lwresd and named with lwres
d432d7594caca8c2587a3ca660c35865538464ceKlaus Luettich configured if when combined with a search list entry the
a7f97f28aa8227408d4008e0b12a7bd925ef51feKlaus Luettich resulting name is too long. This flaw is disclosed in
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich CVE-2016-2775. [RT #42694]
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich </p></li>
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich</ul></div>
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich</div>
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich<div class="section">
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich<div class="titlepage"><div><div><h3 class="title">
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich<a name="relnotes_features"></a>New Features</h3></div></div></div>
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich<div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; ">
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich<li class="listitem">
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich<p>
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich A new method of provisioning secondary servers called
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich "Catalog Zones" has been added. This is an implementation of
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich <a class="link" href="https://datatracker.ietf.org/doc/draft-muks-dnsop-dns-catalog-zones/" target="_top">
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich draft-muks-dnsop-dns-catalog-zones/
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich </a>.
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich </p>
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich<p>
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich A catalog zone is a regular DNS zone which contains a list
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich of "member zones", along with the configuration options for
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich each of those zones. When a server is configured to use a
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich catalog zone, all the zones listed in the catalog zone are
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich added to the local server as slave zones. When the catalog
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich zone is updated (e.g., by adding or removing zones, or
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich changing configuration options for existing zones) those
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich changes will be put into effect. Since the catalog zone is
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich itself a DNS zone, this means configuration changes can be
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich propagated to slaves using the standard AXFR/IXFR update
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich mechanism.
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich </p>
f778a0725b6b62370f1ac3f683caf2a3930920d0Klaus Luettich<p>
a7f97f28aa8227408d4008e0b12a7bd925ef51feKlaus Luettich This feature should be considered experimental. It currently
a7f97f28aa8227408d4008e0b12a7bd925ef51feKlaus Luettich supports only basic features; more advanced features such as
a7f97f28aa8227408d4008e0b12a7bd925ef51feKlaus Luettich ACLs and TSIG keys are not yet supported. Example catalog
a7f97f28aa8227408d4008e0b12a7bd925ef51feKlaus Luettich zone configurations can be found in the Chapter 9 of the
a7f97f28aa8227408d4008e0b12a7bd925ef51feKlaus Luettich BIND Administrator Reference Manual.
a7f97f28aa8227408d4008e0b12a7bd925ef51feKlaus Luettich </p>
a7f97f28aa8227408d4008e0b12a7bd925ef51feKlaus Luettich<p>
a7f97f28aa8227408d4008e0b12a7bd925ef51feKlaus Luettich Support for master entries with TSIG keys has been added to catalog
a7f97f28aa8227408d4008e0b12a7bd925ef51feKlaus Luettich zones, as well as support for allow-query and allow-transfer.
a7f97f28aa8227408d4008e0b12a7bd925ef51feKlaus Luettich </p>
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski</li>
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder<li class="listitem"><p>
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder Added an <span class="command"><strong>isc.rndc</strong></span> Python module, which allows
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski <span class="command"><strong>rndc</strong></span> commands to be sent from Python programs.
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski </p></li>
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski<li class="listitem">
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski<p>
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski Added support for DynDB, a new interface for loading zone data
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski from an external database, developed by Red Hat for the FreeIPA
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski project. (Thanks in particular to Adam Tkac and Petr
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski Spacek of Red Hat for the contribution.)
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski </p>
503e836b34d3abed34520eb4a0a345b5e13f248dTill Mossakowski<p>
56cd0da55d058b262b1626ddcd78db6bd9a90551Christian Maeder Unlike the existing DLZ and SDB interfaces, which provide a
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski limited subset of database functionality within BIND &#8212;
503e836b34d3abed34520eb4a0a345b5e13f248dTill Mossakowski translating DNS queries into real-time database lookups with
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski relatively poor performance and with no ability to handle
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski DNSSEC-signed data &#8212; DynDB is able to fully implement
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski and extend the database API used natively by BIND.
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski </p>
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski<p>
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski A DynDB module could pre-load data from an external data
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski source, then serve it with the same performance and
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski functionality as conventional BIND zones, and with the
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski ability to take advantage of database features not
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder available in BIND, such as multi-master replication.
50ea34ea29d0121f3e692b7029b09d28dc7988fdTill Mossakowski </p>
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski</li>
50ea34ea29d0121f3e692b7029b09d28dc7988fdTill Mossakowski<li class="listitem">
50ea34ea29d0121f3e692b7029b09d28dc7988fdTill Mossakowski<p>
503e836b34d3abed34520eb4a0a345b5e13f248dTill Mossakowski Fetch quotas are now compiled in by default: they
bc2a836a3e05cbfdee8e2acd7a2b5d276d949f61Till Mossakowski no longer require BIND to be configured with
50ea34ea29d0121f3e692b7029b09d28dc7988fdTill Mossakowski <span class="command"><strong>--enable-fetchlimit</strong></span>, as was the case
50ea34ea29d0121f3e692b7029b09d28dc7988fdTill Mossakowski when the feature was introduced in BIND 9.10.3.
50ea34ea29d0121f3e692b7029b09d28dc7988fdTill Mossakowski </p>
50ea34ea29d0121f3e692b7029b09d28dc7988fdTill Mossakowski<p>
50ea34ea29d0121f3e692b7029b09d28dc7988fdTill Mossakowski These quotas limit the queries that are sent by recursive
50ea34ea29d0121f3e692b7029b09d28dc7988fdTill Mossakowski resolvers to authoritative servers experiencing denial-of-service
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski attacks. They can both reduce the harm done to authoritative
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski servers and also avoid the resource exhaustion that can be
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski experienced by recursive servers when they are being used as a
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski vehicle for such an attack.
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski </p>
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski<div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: circle; ">
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder<li class="listitem"><p>
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski <code class="option">fetches-per-server</code> limits the number of
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder simultaneous queries that can be sent to any single
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski authoritative server. The configured value is a starting
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski point; it is automatically adjusted downward if the server is
90ac4d9f9cde1e45015fd7eb7111315184f4eda7Till Mossakowski partially or completely non-responsive. The algorithm used to
16f97ebf071c023e0f3148c9b65a0ebf0c4eefceKlaus Luettich adjust the quota can be configured via the
16f97ebf071c023e0f3148c9b65a0ebf0c4eefceKlaus Luettich <code class="option">fetch-quota-params</code> option.
b10d6cef708b7a659f2d3b367e8e0db0d03ae3f5Till Mossakowski </p></li>
b10d6cef708b7a659f2d3b367e8e0db0d03ae3f5Till Mossakowski<li class="listitem"><p>
b10d6cef708b7a659f2d3b367e8e0db0d03ae3f5Till Mossakowski <code class="option">fetches-per-zone</code> limits the number of
b10d6cef708b7a659f2d3b367e8e0db0d03ae3f5Till Mossakowski simultaneous queries that can be sent for names within a
b10d6cef708b7a659f2d3b367e8e0db0d03ae3f5Till Mossakowski single domain. (Note: Unlike "fetches-per-server", this
16f97ebf071c023e0f3148c9b65a0ebf0c4eefceKlaus Luettich value is not self-tuning.)
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski </p></li>
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski</ul></div>
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski<p>
74e82e43f5787027c5d4e523397525a259d6d001Christian Maeder Statistics counters have also been added to track the number
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski of queries affected by these quotas.
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski </p>
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski</li>
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski<li class="listitem">
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski<p>
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski Added support for <span class="command"><strong>dnstap</strong></span>, a fast,
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski flexible method for capturing and logging DNS traffic,
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski developed by Robert Edmonds at Farsight Security, Inc.,
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski whose assistance is gratefully acknowledged.
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski </p>
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski<p>
90ac4d9f9cde1e45015fd7eb7111315184f4eda7Till Mossakowski To enable <span class="command"><strong>dnstap</strong></span> at compile time,
74e82e43f5787027c5d4e523397525a259d6d001Christian Maeder the <span class="command"><strong>fstrm</strong></span> and <span class="command"><strong>protobuf-c</strong></span>
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski libraries must be available, and BIND must be configured with
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski <code class="option">--enable-dnstap</code>.
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski </p>
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski<p>
320198216ed3bde106b509c4024b857ce4345880Maciek Makowski A new utility <span class="command"><strong>dnstap-read</strong></span> has been added
503e836b34d3abed34520eb4a0a345b5e13f248dTill Mossakowski to allow <span class="command"><strong>dnstap</strong></span> data to be presented in
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski a human-readable format.
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski </p>
cbd084e49e0321158315491472aeb3695e03ec55Maciek Makowski<p>
320198216ed3bde106b509c4024b857ce4345880Maciek Makowski <span class="command"><strong>rndc dnstap -roll</strong></span> causes <span class="command"><strong>dnstap</strong></span>
320198216ed3bde106b509c4024b857ce4345880Maciek Makowski output files to be rolled like log files -- the most recent output
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski file is renamed with a <code class="filename">.0</code> suffix, the next
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski most recent with <code class="filename">.1</code>, etc. (Note that this
320198216ed3bde106b509c4024b857ce4345880Maciek Makowski only works when <span class="command"><strong>dnstap</strong></span> output is being written
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski to a file, not to a UNIX domain socket.) An optional numerical
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski argument specifies how many backup log files to retain; if not
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski specified or set to 0, there is no limit.
320198216ed3bde106b509c4024b857ce4345880Maciek Makowski </p>
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski<p>
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski <span class="command"><strong>rndc dnstap -reopen</strong></span> simply closes and reopens
320198216ed3bde106b509c4024b857ce4345880Maciek Makowski the <span class="command"><strong>dnstap</strong></span> output channel without renaming
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski the output file.
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski </p>
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski<p>
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski For more information on <span class="command"><strong>dnstap</strong></span>, see
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski <a class="link" href="http://dnstap.info" target="_top">http://dnstap.info</a>.
503e836b34d3abed34520eb4a0a345b5e13f248dTill Mossakowski </p>
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski</li>
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski<li class="listitem">
cbd084e49e0321158315491472aeb3695e03ec55Maciek Makowski<p>
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski New statistics counters have been added to track traffic
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski sizes, as specified in RSSAC002. Query and response
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski message sizes are broken up into ranges of histogram buckets:
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski TCP and UDP queries of size 0-15, 16-31, ..., 272-288, and 288+,
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski and TCP and UDP responses of size 0-15, 16-31, ..., 4080-4095,
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski and 4096+. These values can be accessed via the XML and JSON
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski statistics channels at, for example,
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski <a class="link" href="http://localhost:8888/xml/v3/traffic" target="_top">http://localhost:8888/xml/v3/traffic</a>
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski or
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski <a class="link" href="http://localhost:8888/json/v1/traffic" target="_top">http://localhost:8888/json/v1/traffic</a>.
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski </p>
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski<p>
e182d0ec56025d97d74829cac75ee31eec12b093Maciek Makowski Statistics for RSSAC02v3 traffic-volume, traffic-sizes and
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski rcode-volume reporting are now collected.
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski </p>
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski</li>
79831982ddcb41676a033e6f5ab1d60343de1539Christian Maeder<li class="listitem">
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski<p>
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski A new DNSSEC key management utility,
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski <span class="command"><strong>dnssec-keymgr</strong></span>, has been added. This tool
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski is meant to run unattended (e.g., under <span class="command"><strong>cron</strong></span>).
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski It reads a policy definition file
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder (default <code class="filename">/etc/dnssec-policy.conf</code>)
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder and creates or updates DNSSEC keys as necessary to ensure that a
74e82e43f5787027c5d4e523397525a259d6d001Christian Maeder zone's keys match the defined policy for that zone. New keys are
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder created whenever necessary to ensure rollovers occur correctly.
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski Existing keys' timing metadata is adjusted as needed to set the
c616e681da8c052b62e14247fea522da099ac0e4Christian Maeder correct rollover period, prepublication interval, etc. If
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder the configured policy changes, keys are corrected automatically.
21dae7237ac384abdb94a81e00b3f099873ec623Till Mossakowski See the <span class="command"><strong>dnssec-keymgr</strong></span> man page for full details.
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski </p>
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski<p>
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder Note: <span class="command"><strong>dnssec-keymgr</strong></span> depends on Python and on
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder the Python lex/yacc module, PLY. The other Python-based tools,
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder <span class="command"><strong>dnssec-coverage</strong></span> and
58b671de3fe578346fef9642ffa3c5a0a0edb3cbTill Mossakowski <span class="command"><strong>dnssec-checkds</strong></span>, have been
58b671de3fe578346fef9642ffa3c5a0a0edb3cbTill Mossakowski refactored and updated as part of this work.
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski </p>
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski<p>
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski <span class="command"><strong>dnssec-keymgr</strong></span> now takes a -r
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski <em class="replaceable"><code>randomfile</code></em> option.
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski </p>
58b671de3fe578346fef9642ffa3c5a0a0edb3cbTill Mossakowski<p>
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski (Many thanks to Sebasti�n
b10d6cef708b7a659f2d3b367e8e0db0d03ae3f5Till Mossakowski Castro for his assistance in developing this tool at the IETF
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski 95 Hackathon in Buenos Aires, April 2016.)
b10d6cef708b7a659f2d3b367e8e0db0d03ae3f5Till Mossakowski </p>
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski</li>
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski<li class="listitem"><p>
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski The serial number of a dynamically updatable zone can
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski now be set using
b0294d73dcefc502ddaa13e18b46103a5916971fTill Mossakowski <span class="command"><strong>rndc signing -serial <em class="replaceable"><code>number</code></em> <em class="replaceable"><code>zonename</code></em></strong></span>.
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski This is particularly useful with <code class="option">inline-signing</code>
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski zones that have been reset. Setting the serial number to a value
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski larger than that on the slaves will trigger an AXFR-style
bfa9e03532243ceb487f0384d0f6a447f1ce7670Till Mossakowski transfer.
bfa9e03532243ceb487f0384d0f6a447f1ce7670Till Mossakowski </p></li>
58b671de3fe578346fef9642ffa3c5a0a0edb3cbTill Mossakowski<li class="listitem"><p>
58b671de3fe578346fef9642ffa3c5a0a0edb3cbTill Mossakowski When answering recursive queries, SERVFAIL responses can now be
58b671de3fe578346fef9642ffa3c5a0a0edb3cbTill Mossakowski cached by the server for a limited time; subsequent queries for
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski the same query name and type will return another SERVFAIL until
58b671de3fe578346fef9642ffa3c5a0a0edb3cbTill Mossakowski the cache times out. This reduces the frequency of retries
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski when a query is persistently failing, which can be a burden
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski on recursive servers. The SERVFAIL cache timeout is controlled
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski by <code class="option">servfail-ttl</code>, which defaults to 1 second
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski and has an upper limit of 30.
1aa2d970e253d650a50873d5b1213c26b04d90dcJorina Freya Gerken </p></li>
1aa2d970e253d650a50873d5b1213c26b04d90dcJorina Freya Gerken<li class="listitem"><p>
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski The new <span class="command"><strong>rndc nta</strong></span> command can now be used to
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski set a "negative trust anchor" (NTA), disabling DNSSEC validation for
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski a specific domain; this can be used when responses from a domain
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski are known to be failing validation due to administrative error
74e82e43f5787027c5d4e523397525a259d6d001Christian Maeder rather than because of a spoofing attack. NTAs are strictly
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski temporary; by default they expire after one hour, but can be
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski configured to last up to one week. The default NTA lifetime
e379124f467e5d0ef7d3c0ca238bff0521f70831Till Mossakowski can be changed by setting the <code class="option">nta-lifetime</code> in
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski <code class="filename">named.conf</code>. When added, NTAs are stored in a
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski file (<code class="filename"><em class="replaceable"><code>viewname</code></em>.nta</code>)
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski in order to persist across restarts of the <span class="command"><strong>named</strong></span> server.
1b05bdb88b90d3c947351f262d7ae7d68f0a4a6fTill Mossakowski </p></li>
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder<li class="listitem"><p>
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder The EDNS Client Subnet (ECS) option is now supported for
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder authoritative servers; if a query contains an ECS option then
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder ACLs containing <code class="option">geoip</code> or <code class="option">ecs</code>
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder elements can match against the address encoded in the option.
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder This can be used to select a view for a query, so that different
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder answers can be provided depending on the client network.
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder </p></li>
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder<li class="listitem"><p>
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder The EDNS EXPIRE option has been implemented on the client
74e82e43f5787027c5d4e523397525a259d6d001Christian Maeder side, allowing a slave server to set the expiration timer
c616e681da8c052b62e14247fea522da099ac0e4Christian Maeder correctly when transferring zone data from another slave
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder server.
74e82e43f5787027c5d4e523397525a259d6d001Christian Maeder </p></li>
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder<li class="listitem"><p>
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder A new <code class="option">masterfile-style</code> zone option controls
d21dd452cd68abade683103a5c0cfe6d02c5f17bTill Mossakowski the formatting of text zone files: When set to
c616e681da8c052b62e14247fea522da099ac0e4Christian Maeder <code class="literal">full</code>, the zone file will dumped in
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder single-line-per-record format.
d21dd452cd68abade683103a5c0cfe6d02c5f17bTill Mossakowski </p></li>
d21dd452cd68abade683103a5c0cfe6d02c5f17bTill Mossakowski<li class="listitem"><p>
d21dd452cd68abade683103a5c0cfe6d02c5f17bTill Mossakowski <span class="command"><strong>dig +ednsopt</strong></span> can now be used to set
d21dd452cd68abade683103a5c0cfe6d02c5f17bTill Mossakowski arbitrary EDNS options in DNS requests.
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder </p></li>
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder<li class="listitem"><p>
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder <span class="command"><strong>dig +ednsflags</strong></span> can now be used to set
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder yet-to-be-defined EDNS flags in DNS requests.
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder </p></li>
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder<li class="listitem"><p>
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder <span class="command"><strong>dig +[no]ednsnegotiation</strong></span> can now be used enable /
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder disable EDNS version negotiation.
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder </p></li>
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder<li class="listitem"><p>
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder <span class="command"><strong>dig +header-only</strong></span> can now be used to send
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder queries without a question section.
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder </p></li>
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder<li class="listitem"><p>
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder <span class="command"><strong>dig +ttlunits</strong></span> causes <span class="command"><strong>dig</strong></span>
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder to print TTL values with time-unit suffixes: w, d, h, m, s for
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder weeks, days, hours, minutes, and seconds.
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder </p></li>
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder<li class="listitem"><p>
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder <span class="command"><strong>dig +zflag</strong></span> can be used to set the last
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder unassigned DNS header flag bit. This bit is normally zero.
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder </p></li>
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder<li class="listitem"><p>
d21dd452cd68abade683103a5c0cfe6d02c5f17bTill Mossakowski <span class="command"><strong>dig +dscp=<em class="replaceable"><code>value</code></em></strong></span>
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder can now be used to set the DSCP code point in outgoing query
d21dd452cd68abade683103a5c0cfe6d02c5f17bTill Mossakowski packets.
d21dd452cd68abade683103a5c0cfe6d02c5f17bTill Mossakowski </p></li>
d21dd452cd68abade683103a5c0cfe6d02c5f17bTill Mossakowski<li class="listitem"><p>
f69658e57cba7ecb37c0d84181f4c563215c2534Till Mossakowski <span class="command"><strong>dig +mapped</strong></span> can now be used to determine
d21dd452cd68abade683103a5c0cfe6d02c5f17bTill Mossakowski if mapped IPv4 addresses can be used.
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder </p></li>
95c3e5d11dcee331dc3876a9bf0c1d6daa38e2caChristian Maeder<li class="listitem"><p>
<span class="command"><strong>nslookup</strong></span> will now look up IPv6 as well
as IPv4 addresses by default. [RT #40420]
</p></li>
<li class="listitem"><p>
<code class="option">serial-update-method</code> can now be set to
<code class="literal">date</code>. On update, the serial number will
be set to the current date in YYYYMMDDNN format.
</p></li>
<li class="listitem"><p>
<span class="command"><strong>dnssec-signzone -N date</strong></span> also sets the serial
number to YYYYMMDDNN.
</p></li>
<li class="listitem"><p>
<span class="command"><strong>named -L <em class="replaceable"><code>filename</code></em></strong></span>
causes <span class="command"><strong>named</strong></span> to send log messages to the
specified file by default instead of to the system log.
</p></li>
<li class="listitem"><p>
The rate limiter configured by the
<code class="option">serial-query-rate</code> option no longer covers
NOTIFY messages; those are now separately controlled by
<code class="option">notify-rate</code> and
<code class="option">startup-notify-rate</code> (the latter of which
controls the rate of NOTIFY messages sent when the server
is first started up or reconfigured).
</p></li>
<li class="listitem"><p>
The default number of tasks and client objects available
for serving lightweight resolver queries have been increased,
and are now configurable via the new <code class="option">lwres-tasks</code>
and <code class="option">lwres-clients</code> options in
<code class="filename">named.conf</code>. [RT #35857]
</p></li>
<li class="listitem"><p>
Log output to files can now be buffered by specifying
<span class="command"><strong>buffered yes;</strong></span> when creating a channel.
</p></li>
<li class="listitem"><p>
<span class="command"><strong>delv +tcp</strong></span> will exclusively use TCP when
sending queries.
</p></li>
<li class="listitem"><p>
<span class="command"><strong>named</strong></span> will now check to see whether
other name server processes are running before starting up.
This is implemented in two ways: 1) by refusing to start
if the configured network interfaces all return "address
in use", and 2) by attempting to acquire a lock on a file
specified by the <code class="option">lock-file</code> option or
the <span class="command"><strong>-X</strong></span> command line option. The
default lock file is
<code class="filename">/var/run/named/named.lock</code>.
Specifying <code class="literal">none</code> will disable the lock
file check.
</p></li>
<li class="listitem"><p>
<span class="command"><strong>rndc delzone</strong></span> can now be applied to zones
which were configured in <code class="filename">named.conf</code>;
it is no longer restricted to zones which were added by
<span class="command"><strong>rndc addzone</strong></span>. (Note, however, that
this does not edit <code class="filename">named.conf</code>; the zone
must be removed from the configuration or it will return
when <span class="command"><strong>named</strong></span> is restarted or reloaded.)
</p></li>
<li class="listitem"><p>
<span class="command"><strong>rndc modzone</strong></span> can be used to reconfigure
a zone, using similar syntax to <span class="command"><strong>rndc addzone</strong></span>.
</p></li>
<li class="listitem"><p>
<span class="command"><strong>rndc showzone</strong></span> displays the current
configuration for a specified zone.
</p></li>
<li class="listitem">
<p>
When BIND is built with the <span class="command"><strong>lmdb</strong></span> library
(Lightning Memory-Mapped Database), <span class="command"><strong>named</strong></span>
will store the configuration information for zones
that are added via <span class="command"><strong>rndc addzone</strong></span>
in a database, rather than in a flat "NZF" file. This
dramatically improves performance for
<span class="command"><strong>rndc delzone</strong></span> and
<span class="command"><strong>rndc modzone</strong></span>: deleting or changing
the contents of a database is much faster than rewriting
a text file.
</p>
<p>
On startup, if <span class="command"><strong>named</strong></span> finds an existing
NZF file, it will automatically convert it to the new NZD
database format.
</p>
<p>
To view the contents of an NZD, or to convert an
NZD back to an NZF file (for example, to revert back
to an earlier version of BIND which did not support the
NZD format), use the new command <span class="command"><strong>named-nzd2nzf</strong></span>
[RT #39837]
</p>
</li>
<li class="listitem">
<p>
Added server-side support for pipelined TCP queries. Clients
may continue sending queries via TCP while previous queries are
processed in parallel. Responses are sent when they are
ready, not necessarily in the order in which the queries were
received.
</p>
<p>
To revert to the former behavior for a particular
client address or range of addresses, specify the address prefix
in the "keep-response-order" option. To revert to the former
behavior for all clients, use "keep-response-order { any; };".
</p>
</li>
<li class="listitem"><p>
The new <span class="command"><strong>mdig</strong></span> command is a version of
<span class="command"><strong>dig</strong></span> that sends multiple pipelined
queries and then waits for responses, instead of sending one
query and waiting the response before sending the next. [RT #38261]
</p></li>
<li class="listitem"><p>
To enable better monitoring and troubleshooting of RFC 5011
trust anchor management, the new <span class="command"><strong>rndc managed-keys</strong></span>
can be used to check status of trust anchors or to force keys
to be refreshed. Also, the managed-keys data file now has
easier-to-read comments. [RT #38458]
</p></li>
<li class="listitem"><p>
An <span class="command"><strong>--enable-querytrace</strong></span> configure switch is
now available to enable very verbose query trace logging. This
option can only be set at compile time. This option has a
negative performance impact and should be used only for
debugging. [RT #37520]
</p></li>
<li class="listitem"><p>
A new <span class="command"><strong>tcp-only</strong></span> option can be specified
in <span class="command"><strong>server</strong></span> statements to force
<span class="command"><strong>named</strong></span> to connect to the specified
server via TCP. [RT #37800]
</p></li>
<li class="listitem"><p>
The <span class="command"><strong>nxdomain-redirect</strong></span> option specifies
a DNS namespace to use for NXDOMAIN redirection. When a
recursive lookup returns NXDOMAIN, a second lookup is
initiated with the specified name appended to the query
name. This allows NXDOMAIN redirection data to be supplied
by multiple zones configured on the server, or by recursive
queries to other servers. (The older method, using
a single <span class="command"><strong>type redirect</strong></span> zone, has
better average performance but is less flexible.) [RT #37989]
</p></li>
<li class="listitem"><p>
The following types have been implemented: CSYNC, NINFO, RKEY,
SINK, TA, TALINK.
</p></li>
<li class="listitem"><p>
A new <span class="command"><strong>message-compression</strong></span> option can be
used to specify whether or not to use name compression when
answering queries. Setting this to <strong class="userinput"><code>no</code></strong>
results in larger responses, but reduces CPU consumption and
may improve throughput. The default is <strong class="userinput"><code>yes</code></strong>.
</p></li>
<li class="listitem"><p>
A <span class="command"><strong>read-only</strong></span> option is now available in the
<span class="command"><strong>controls</strong></span> statement to grant non-destructive
control channel access. In such cases, a restricted set of
<span class="command"><strong>rndc</strong></span> commands are allowed, which can
report information from <span class="command"><strong>named</strong></span>, but cannot
reconfigure or stop the server. By default, the control channel
access is <span class="emphasis"><em>not</em></span> restricted to these
read-only operations. [RT #40498]
</p></li>
<li class="listitem"><p>
When loading a signed zone, <span class="command"><strong>named</strong></span> will
now check whether an RRSIG's inception time is in the future,
and if so, it will regenerate the RRSIG immediately. This helps
when a system's clock needs to be reset backwards.
</p></li>
<li class="listitem"><p>
The new <span class="command"><strong>minimal-any</strong></span> option reduces the size
of answers to UDP queries for type ANY by implementing one of
the strategies in "draft-ietf-dnsop-refuse-any": returning
a single arbitrarily-selected RRset that matches the query
name rather than returning all of the matching RRsets.
Thanks to Tony Finch for the contribution. [RT #41615]
</p></li>
<li class="listitem"><p>
<span class="command"><strong>named</strong></span> now provides feedback to the
owners of zones which have trust anchors configured
(<span class="command"><strong>trusted-keys</strong></span>,
<span class="command"><strong>managed-keys</strong></span>, <span class="command"><strong>dnssec-validation
auto;</strong></span> and <span class="command"><strong>dnssec-lookaside auto;</strong></span>)
by sending a daily query which encodes the keyids of the
configured trust anchors for the zone. This is controlled
by <span class="command"><strong>trust-anchor-telemetry</strong></span> and defaults
to yes.
</p></li>
</ul></div>
</div>
<div class="section">
<div class="titlepage"><div><div><h3 class="title">
<a name="relnotes_changes"></a>Feature Changes</h3></div></div></div>
<div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; ">
<li class="listitem"><p>
The ISC DNSSEC Lookaside Validation (DLV) service is scheduled
to be disabled in 2017. A warning is now logged when
<span class="command"><strong>named</strong></span> is configured to use this service,
either explicitly or via <code class="option">dnssec-lookaside auto;</code>.
[RT #42207]
</p></li>
<li class="listitem"><p>
The timers returned by the statistics channel (indicating current
time, server boot time, and most recent reconfiguration time) are
now reported with millisecond accuracy. [RT #40082]
</p></li>
<li class="listitem"><p>
Updated the compiled-in addresses for H.ROOT-SERVERS.NET
and L.ROOT-SERVERS.NET.
</p></li>
<li class="listitem"><p>
ACLs containing <span class="command"><strong>geoip asnum</strong></span> elements were
not correctly matched unless the full organization name was
specified in the ACL (as in
<span class="command"><strong>geoip asnum "AS1234 Example, Inc.";</strong></span>).
They can now match against the AS number alone (as in
<span class="command"><strong>geoip asnum "AS1234";</strong></span>).
</p></li>
<li class="listitem"><p>
When using native PKCS#11 cryptography (i.e.,
<span class="command"><strong>configure --enable-native-pkcs11</strong></span>) HSM PINs
of up to 256 characters can now be used.
</p></li>
<li class="listitem"><p>
NXDOMAIN responses to queries of type DS are now cached separately
from those for other types. This helps when using "grafted" zones
of type forward, for which the parent zone does not contain a
delegation, such as local top-level domains. Previously a query
of type DS for such a zone could cause the zone apex to be cached
as NXDOMAIN, blocking all subsequent queries. (Note: This
change is only helpful when DNSSEC validation is not enabled.
"Grafted" zones without a delegation in the parent are not a
recommended configuration.)
</p></li>
<li class="listitem"><p>
Update forwarding performance has been improved by allowing
a single TCP connection to be shared between multiple updates.
</p></li>
<li class="listitem"><p>
By default, <span class="command"><strong>nsupdate</strong></span> will now check
the correctness of hostnames when adding records of type
A, AAAA, MX, SOA, NS, SRV or PTR. This behavior can be
disabled with <span class="command"><strong>check-names no</strong></span>.
</p></li>
<li class="listitem"><p>
Added support for OPENPGPKEY type.
</p></li>
<li class="listitem"><p>
The names of the files used to store managed keys and added
zones for each view are no longer based on the SHA256 hash
of the view name, except when this is necessary because the
view name contains characters that would be incompatible with use
as a file name. For views whose names do not contain forward
slashes ('/'), backslashes ('\'), or capital letters - which
could potentially cause namespace collision problems on
case-insensitive filesystems - files will now be named
after the view (for example, <code class="filename">internal.mkeys</code>
or <code class="filename">external.nzf</code>). However, to ensure
consistent behavior when upgrading, if a file using the old
name format is found to exist, it will continue to be used.
</p></li>
<li class="listitem"><p>
"rndc" can now return text output of arbitrary size to
the caller. (Prior to this, certain commands such as
"rndc tsig-list" and "rndc zonestatus" could return
truncated output.)
</p></li>
<li class="listitem"><p>
Errors reported when running <span class="command"><strong>rndc addzone</strong></span>
(e.g., when a zone file cannot be loaded) have been clarified
to make it easier to diagnose problems.
</p></li>
<li class="listitem"><p>
When encountering an authoritative name server whose name is
an alias pointing to another name, the resolver treats
this as an error and skips to the next server. Previously
this happened silently; now the error will be logged to
the newly-created "cname" log category.
</p></li>
<li class="listitem"><p>
If <span class="command"><strong>named</strong></span> is not configured to validate
answers, then allow fallback to plain DNS on timeout even when
we know the server supports EDNS. This will allow the server to
potentially resolve signed queries when TCP is being
blocked.
</p></li>
<li class="listitem"><p>
Large inline-signing changes should be less disruptive.
Signature generation is now done incrementally; the number
of signatures to be generated in each quantum is controlled
by "sig-signing-signatures <em class="replaceable"><code>number</code></em>;".
[RT #37927]
</p></li>
<li class="listitem">
<p>
The experimental SIT option (code point 65001) of BIND
9.10.0 through BIND 9.10.2 has been replaced with the COOKIE
option (code point 10). It is no longer experimental, and
is sent by default, by both <span class="command"><strong>named</strong></span> and
<span class="command"><strong>dig</strong></span>.
</p>
<p>
The SIT-related named.conf options have been marked as
obsolete, and are otherwise ignored.
</p>
</li>
<li class="listitem"><p>
When <span class="command"><strong>dig</strong></span> receives a truncated (TC=1)
response or a BADCOOKIE response code from a server, it
will automatically retry the query using the server COOKIE
that was returned by the server in its initial response.
[RT #39047]
</p></li>
<li class="listitem"><p>
Retrieving the local port range from net.ipv4.ip_local_port_range
on Linux is now supported.
</p></li>
<li class="listitem"><p>
A new <code class="option">nsip-wait-recurse</code> directive has been
added to RPZ, specifying whether to look up unknown name server
IP addresses and wait for a response before applying RPZ-NSIP rules.
The default is <strong class="userinput"><code>yes</code></strong>. If set to
<strong class="userinput"><code>no</code></strong>, <span class="command"><strong>named</strong></span> will only
apply RPZ-NSIP rules to servers whose addresses are already cached.
The addresses will be looked up in the background so the rule can
be applied on subsequent queries. This improves performance when
the cache is cold, at the cost of temporary imprecision in applying
policy directives. [RT #35009]
</p></li>
<li class="listitem"><p>
Within the <code class="option">response-policy</code> option, it is now
possible to configure RPZ rewrite logging on a per-zone basis
using the <code class="option">log</code> clause.
</p></li>
<li class="listitem"><p>
The default preferred glue is now the address type of the
transport the query was received over.
</p></li>
<li class="listitem"><p>
On machines with 2 or more processors (CPU), the default value
for the number of UDP listeners has been changed to the number
of detected processors minus one.
</p></li>
<li class="listitem"><p>
Zone transfers now use smaller message sizes to improve
message compression. This results in reduced network usage.
</p></li>
<li class="listitem">
<p>
Added support for the AVC resource record type (Application
Visibility and Control).
</p>
<p>
Changed <span class="command"><strong>rndc reconfig</strong></span> behavior so that newly
added zones are loaded asynchronously and the loading does not
block the server.
</p>
</li>
<li class="listitem"><p>
<span class="command"><strong>minimal-responses</strong></span> now takes two new
arguments: <code class="option">no-auth</code> suppresses
populating the authority section but not the additional
section; <code class="option">no-auth-recursive</code>
does the same but only when answering recursive queries.
</p></li>
<li class="listitem"><p>
At server startup time, the queues for processing
notify and zone refresh queries are now processed in
LIFO rather than FIFO order, to speed up
loading of newly added zones. [RT #42825]
</p></li>
<li class="listitem"><p>
When answering queries of type MX or SRV, TLSA records for
the target name are now included in the additional section
to speed up DANE processing. [RT #42894]
</p></li>
<li class="listitem"><p>
<span class="command"><strong>named</strong></span> can now use the TCP Fast Open
mechanism on the server side, if supported by the
local operating system. [RT #42866]
</p></li>
</ul></div>
</div>
<div class="section">
<div class="titlepage"><div><div><h3 class="title">
<a name="relnotes_bugs"></a>Bug Fixes</h3></div></div></div>
<div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; ">
<li class="listitem"><p>
Fixed a crash when calling <span class="command"><strong>rndc stats</strong></span> on some
Windows builds: some Visual Studio compilers generate code that
crashes when the "%z" printf() format specifier is used. [RT #42380]
</p></li>
<li class="listitem"><p>
Windows installs were failing due to triggering UAC without
the installation binary being signed.
</p></li>
<li class="listitem"><p>
A change in the internal binary representation of the RBT database
node structure enabled a race condition to occur (especially when
BIND was built with certain compilers or optimizer settings),
leading to inconsistent database state which caused random
assertion failures. [RT #42380]
</p></li>
</ul></div>
</div>
<div class="section">
<div class="titlepage"><div><div><h3 class="title">
<a name="end_of_life"></a>End of Life</h3></div></div></div>
<p>
The end of life for BIND 9.11 is yet to be determined but
will not be before BIND 9.13.0 has been released for 6 months.
<a class="link" href="https://www.isc.org/downloads/software-support-policy/" target="_top">https://www.isc.org/downloads/software-support-policy/</a>
</p>
</div>
<div class="section">
<div class="titlepage"><div><div><h3 class="title">
<a name="relnotes_thanks"></a>Thank You</h3></div></div></div>
<p>
Thank you to everyone who assisted us in making this release possible.
If you would like to contribute to ISC to assist us in continuing to
make quality open source software, please visit our donations page at
<a class="link" href="http://www.isc.org/donate/" target="_top">http://www.isc.org/donate/</a>.
</p>
</div>
</div>
</div>
<div class="navfooter">
<hr>
<table width="100%" summary="Navigation footer">
<tr>
<td width="40%" align="left">
<a accesskey="p" href="Bv9ARM.ch08.html">Prev</a>�</td>
<td width="20%" align="center">�</td>
<td width="40%" align="right">�<a accesskey="n" href="Bv9ARM.ch10.html">Next</a>
</td>
</tr>
<tr>
<td width="40%" align="left" valign="top">Chapter�8.�Troubleshooting�</td>
<td width="20%" align="center"><a accesskey="h" href="Bv9ARM.html">Home</a></td>
<td width="40%" align="right" valign="top">�Appendix�B.�A Brief History of the <acronym class="acronym">DNS</acronym> and <acronym class="acronym">BIND</acronym>
</td>
</tr>
</table>
</div>
<p xmlns:db="http://docbook.org/ns/docbook" style="text-align: center;">BIND 9.11.0rc3</p>
</body>
</html>