Release Notes
Introduction
BIND 9.18 (Extended Support Version) is a stable branch of BIND. This document summarizes significant changes since the last production release on that branch. Please see the Changelog file for a more detailed list of changes and bug fixes.
Supported Platforms
See the Supported Platforms section in the Resource Requirements chapter.
Download
The latest versions of BIND 9 software can always be found at https://www.isc.org/download/. There you will find additional information about each release, and source code.
Known Issues
The list of known issues affecting the latest version in the 9.18 branch can be found at https://gitlab.isc.org/isc-projects/bind9/-/wikis/Known-Issues-in-BIND-9.18
Notes for BIND 9.18.39
New Features
- Support for parsing the DSYNC record has been added. 
Feature Changes
- Add deprecation warnings for RSASHA1, RSASHA1-NSEC3SHA1, and DS digest type 1. - RSASHA1 and RSASHA1-NSEC-SHA1 DNSKEY algorithms have been deprecated by the IETF and should no longer be used for DNSSEC. DS digest type 1 (SHA1) has also been deprecated in BIND 9. Validators are now expected to treat these algorithms and digest as unknown, resulting in some zones being treated as insecure when they were previously treated as secure. Warnings have been added to - namedand tools when these algorithms and this digest are being used for signing.- Zones signed with RSASHA1 or RSASHA1-NSEC-SHA1 should be migrated to a different DNSKEY algorithm. - Zones with DS or CDS records with digest type 1 (SHA1) should be updated to use a different digest type (e.g. SHA256) and the digest type 1 records should be removed. [GL #5358] 
Bug Fixes
- Clean enough memory when adding new ADB names/entries under memory pressure. - The ADB memory cleaning is opportunistic even when BIND is under memory pressure (in the overmem condition). The opportunistic LRU cleaning and overmem cleaning have been split, and the overmem cleaning always cleans up double of the newly allocated adbname/adbentry to ensure we never allocate more memory than the assigned limit. [GL !10637] 
- Rescan the interfaces again when reconfiguring the server. - Previously on FreeBSD, the server did not listen on the configured - localhostinterfaces immediately, but only after the- interface-intervalperiod had passed. After an earlier fix, the server would listen on the- localhostafter 60 minutes.- Now, the interfaces are rescanned immediately after configuring the - interface-intervalvalue and begin listening on the- localhostinterface immediately. [GL !10758]
Notes for BIND 9.18.38
Security Fixes
- Fix an issue when some specific queries could remain unanswered with serve-stale enabled. - When - namedwas running with stale answers enabled and with the- stale-answer-client-timeoutconfiguration option set to- 0, in certain situations it was possible that some queries could remain unanswered. This has been fixed. [GL #5383]
New Features
- Add support for the CO flag to - dig.- Add support for Compact Denial of Existence to - dig. This includes showing the CO (Compact Answers OK) flag when displaying messages and adding an option to set the CO flag when making queries (- dig +coflag). [GL #5319]
Bug Fixes
- Correct the default - interface-intervalfrom 60s to 60m.- When the - interface-intervalparser was changed from a- uint32parser to a duration parser, the default value stayed at plain number- 60which now means 60 seconds instead of 60 minutes. The documentation also incorrectly states that the value is in minutes. That has been fixed. [GL #5246]
- Fix a - purge-keysbug when using multiple views of a zone.- Previously, when a DNSSEC key was purged by one zone view, other zone views would return an error about missing key files. This has been fixed. [GL #5315] 
Notes for BIND 9.18.37
Notes for BIND 9.18.36
Feature Changes
- Make TLS data processing more reliable in various network conditions. - BIND now deciphers incoming TLS data before processing it, making it more similar to the handling of TCP. This results in a more predictable behavior, particularly when reading from the stream is paused or resumed. Previously, this could result in an assertion failure when using XFR over TLS (XoT). This has been fixed. [GL #5247] 
Bug Fixes
- Stop caching lack of EDNS support. - namedcould falsely learn that a server did not support EDNS when a spoofed response was received; that subsequently prevented DNSSEC lookups from being made. This has been fixed. [GL #3949] [GL #5066]
- Fix resolver statistics counters for timed-out responses. - When query responses timed out, the resolver could incorrectly increase the regular response counters, even if no response was received. This has been fixed. [GL #5193] 
- Don’t enforce NOAUTH/NOCONF flags in DNSKEYs. - All DNSKEY keys are able to authenticate. The - DNS_KEYTYPE_NOAUTH(and- DNS_KEYTYPE_NOCONF) flags were defined for the KEY rdata type, and are not applicable to DNSKEY. Previously, however, because the DNSKEY implementation was built on top of KEY, the- _NOAUTHflag prevented authentication in DNSKEYs as well. This has been corrected. [GL #5240]
- Fix inconsistency in CNAME/DNAME handling during resolution. - Previously, in some cases, the resolver could return rdatasets of type CNAME or DNAME without the result code being set to - DNS_R_CNAMEor- DNS_R_DNAME. This could trigger an assertion failure. This has been fixed. [GL #5201]
Notes for BIND 9.18.35
Bug Fixes
- Fix deferred validation of unsigned DS and DNSKEY records. - When processing a query with the “checking disabled” bit set (CD=1), - namedstores the invalidated result in the cache, marked “pending”. When the same query is sent with CD=0, the cached data is validated and either accepted as an answer, or ejected from the cache as invalid. This deferred validation was not attempted for DS and DNSKEY records if they had no cached signatures, causing spurious validation failures. The deferred validation is now completed in this scenario.- Also, if deferred validation fails, the data is now re-queried to find out whether the zone has been corrected since the invalid data was cached. [GL #5066] 
- Fix RPZ race condition during a reconfiguration. - With RPZ in use, - namedcould terminate unexpectedly because of a race condition when a reconfiguration command was received using- rndc. This has been fixed. [GL #5146]
- “CNAME and other data check” not applied to all types. - An incorrect optimization caused “CNAME and other data” errors not to be detected if certain types were at the same node as a CNAME. This has been fixed. [GL #5150] 
- Remove NSEC/DS/NSEC3 RRSIG check from - dns_message_parse().- Previously, when parsing responses, - namedincorrectly rejected responses without matching RRSIG records for NSEC/DS/NSEC3 records in the authority section. This rejection, if appropriate, should have been left for the validator to determine and has been fixed. [GL #5185]
Notes for BIND 9.18.34
New Features
- Print the expiration time of the stale records. - Print the expiration time of the stale RRsets in the cache dump. 
Removed Features
- Remove –with-tuning=small/large configuration option. - The configuration option –with-tuning has been removed as it is no longer required or desired. 
Bug Fixes
- Fix - rndc flushnamefor longer name server names.- rndc flushnamedid not work for name server names longer than 16 bytes. This has been fixed. [GL #3885]
- Recently expired records could be returned with a timestamp in future. - Under rare circumstances, an RRSet that expired at the time of the query could be returned with a TTL in the future. This has been fixed. - As a side effect, the expiration time of expired RRSets is no longer returned in a cache dump. [GL #5094] 
- YAML string not terminated in negative response in delv. 
- Apply the memory limit only to ADB database items. - Under heavy load, a resolver could exhaust the memory available for storing the information in the Address Database (ADB), effectively discarding previously stored information in the ADB. The memory used to retrieve and provide information from the ADB is no longer subject to the same memory limits that are applied to - the Address Database. [GL #5127] 
- Avoid unnecessary locking in the zone/cache database. - Lock contention among many worker threads referring to the same database node at the same time is now prevented. This improves zone and cache database performance for any heavily contended database nodes. [GL #5130] 
- Improve the resolver performance under attack. - Previously, a remote client could force the DNS resolver component to consume memory faster than resources were cleaned up for the canceled resolver fetches, due to the recursive-clients limit. If such a traffic pattern was sustained for a long period of time, the DNS server might eventually run out of the available memory. This has been fixed. - It should be noted that, under such a heavy attack, no outgoing DNS queries will be successful in BIND 9 versions both with and without the fix, as the generated traffic pattern will consume all the available slots for the recursive clients. 
Notes for BIND 9.18.33
Security Fixes
- DNS-over-HTTPS flooding fixes. (CVE-2024-12705) - Fix DNS-over-HTTPS implementation issues that arise under heavy query load. Optimize resource usage for - namedinstances that accept queries over DNS-over-HTTPS.- Previously, - namedprocessed all incoming HTTP/2 data at once, which could overwhelm the server, especially when dealing with clients that sent requests but did not wait for responses. That has been fixed. Now,- namedhandles HTTP/2 data in smaller chunks and throttles reading until the remote side reads the response data. It also throttles clients that send too many requests at once.- In addition, - namednow evaluates excessive streams opened by clients that include no DNS data, which is considered “flooding.” It logs these clients and drops connections from them. [GL #4795]- In some cases, - namedcould leave DNS-over-HTTPS connections in the CLOSE_WAIT state indefinitely. That has also been fixed. [GL #5083]- ISC would like to thank Jean-François Billaud for his assistance with investigating this issue. 
- Limit additional section processing for large RDATA sets. (CVE-2024-11187) - When answering queries, don’t add data to the additional section if the answer has more than 13 names in the RDATA. This limits the number of lookups into the database(s) during a single client query, reducing the query-processing load. [GL #5034] - ISC would like to thank Toshifumi Sakaguchi for bringing this vulnerability to our attention. 
New Features
- Add a new option to configure the maximum number of outgoing queries per client request. - The configuration option - max-query-countsets how many outgoing queries per client request are allowed. The existing- max-recursion-queriesvalue is the number of permissible queries for a single name and is reset on every CNAME redirection. This new option is a global limit on the client request. The default is 200.- The default for - max-recursion-queriesis changed from 32 to 50. This allows- namedto send a few more queries while looking up a single name. [GL #4980] [GL #4921]
Bug Fixes
- Fix - nsupdatehang when processing a large update.- To mitigate DNS flood attacks over a single TCP connection, throttle the connection when the other side does not read the data. Throttling should only occur on server-side sockets, but erroneously also happened for - nsupdate, which acts as a client. When- nsupdatestarted throttling the connection, it never attempted to read again. This has been fixed. [GL #4910]
- Fix possible assertion failure when reloading server while processing update policy rules. [GL #5006] 
- Fix - dnssec-signzonesigning non-DNSKEY RRsets with revoked keys.- dnssec-signzonewas using revoked keys for signing RRsets other than DNSKEY. This has been corrected. [GL #5070]
- Fix improper handling of unknown directives in - resolv.conf.- The line after an unknown directive in - resolv.confcould accidentally be skipped, potentially affecting- dig,- host,- nslookup,- nsupdate, or- delv. This has been fixed. [GL #5084]
Notes for BIND 9.18.32
New Features
- Update built-in - bind.keysfile with the new 2025 IANA root key.- Add an initial-ds entry to - bind.keysfor the new root key, ID 38696, which is scheduled for publication in January 2025. [GL #4896]
Removed Features
- Move contributed DLZ modules into a separate repository. DLZ modules should not be used except in testing. - The DLZ modules were not maintained, the DLZ interface itself is going to be scheduled for removal, and the DLZ interface is blocking. Any module that blocks the query to the - databaseblocks the whole server.- The DLZ modules now live in https://gitlab.isc.org/isc-projects/dlz-modules repository. [GL #4865] 
Feature Changes
- Emit more helpful log messages for exceeding - max-records-per-type.- The new log message is emitted when adding or updating an RRset fails due to exceeding the - max-records-per-typelimit. The log includes the owner name and type, corresponding zone name, and the limit value. It will be emitted on loading a zone file, inbound zone transfer (both AXFR and IXFR), handling a DDNS update, or updating a cache DB. It’s especially helpful in the case of zone transfer, since the secondary side doesn’t have direct access to the offending zone data.- It could also be used for - max-types-per-name, but this change doesn’t implement it yet as it’s much less likely to happen in practice.
- Harden key management when key files have become unavailable. - Prior to doing key management, BIND 9 will check if the key files on disk match the expected keys. If key files for previously observed keys have become unavailable, this will prevent the internal key manager from running. 
Bug Fixes
- {&dns} is as valid as {?dns} in a SVCB’s dohpath. - digfailed to parse a valid SVCB record with a dohpath URI template containing a {&dns}, like dohpath=/some/path?key=value{&dns}”. [GL #4922]
- Fix NSEC3 closest encloser lookup for names with empty non-terminals. - A previous performance optimization for finding the NSEC3 closest encloser when generating authoritative responses could cause servers to return incorrect NSEC3 records in some cases. This faulty optimization has been removed. [GL #4950] 
- digoptions of the form [+-]option=<value> failed to display the value on the printed command line. This has been fixed. [GL #4993]
- Provide more visibility into TLS configuration errors by logging SSL_CTX_use_certificate_chain_file() and SSL_CTX_use_PrivateKey_file() errors individually. [GL #5008] 
Notes for BIND 9.18.31
New Features
- Added WALLET type. - Add the new record type WALLET (262). This provides a mapping from a domain name to a cryptographic currency wallet. Multiple mappings can exist if multiple records exist. [GL #4947] 
Feature Changes
- Allow IXFR-to-AXFR fallback on - DNS_R_TOOMANYRECORDS.- This change allows fallback from an IXFR failure to AXFR when the reason is - DNS_R_TOOMANYRECORDS. [GL #4928]
Bug Fixes
- Fix a statistics channel counter bug when “forward only” zones are used. - When resolving a zone with a “forward only” policy, and finding out that all the forwarders were marked as “bad”, the “ServerQuota” counter of the statistics channel was incorrectly increased. This has been fixed. [GL #1793] 
- Fix a bug in the static-stub implementation. - Static-stub addresses and addresses from other sources were being mixed together, resulting in static-stub queries going to addresses not specified in the configuration, or alternatively, static-stub addresses being used instead of the correct server addresses. [GL #4850] 
- Don’t allow - statistics-channelsif libxml2 and libjson-c are not configured.- When BIND 9 is not configured with the libxml2 and libjson-c libraries, the use of the - statistics-channelsoption is a fatal error. [GL #4895]
- Limit the outgoing UDP send queue size. - If the operating system UDP queue got full and the outgoing UDP sending started to be delayed, BIND 9 could exhibit memory spikes as it tried to enqueue all the outgoing UDP messages. It now tries to deliver the outgoing UDP messages synchronously; if that fails, it drops the outgoing DNS message that would get queued up and then timeout on the client side. [GL #4930] 
- Do not set - SO_INCOMING_CPU.- Remove the - SO_INCOMING_CPUsetting as kernel scheduling performs better without constraints. [GL #4936]
Known Issues
- There are no new known issues with this release. See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.30
New Features
- Print the full path of the working directory in startup log messages. - namednow prints its initial working directory during startup, and the changed working directory when loading or reloading its configuration file, if it has a valid- directoryoption defined. [GL #4731]
Feature Changes
- Improve performance for queries that require an NSEC3 wildcard proof. - Rather than starting from the longest matching part of the requested name, lookup the shortest partial match. Most of the time this will be the actual closest encloser. [GL #4460] 
- Follow the number of CPUs set by - taskset/- cpuset.- Administrators may wish to constrain the set of cores that - namedruns on via the- taskset,- cpuset, or- numactlprograms (or equivalents on other OSes).- If the admin has used - taskset,- namednow automatically uses the given number of CPUs rather than the system-wide count. [GL #4884]
Bug Fixes
- Verification of the privacy of an EDDSA key was broken. - The check could lead to an attempt to sign records with a public key, which could cause a segmentation failure (read of a NULL pointer) within OpenSSL. This has been fixed. [GL #4855] 
- Fix algorithm rollover bug when there are two keys with the same keytag. - If there was an algorithm rollover and two keys of different algorithms shared the same keytags, there was the possibility that the check of whether the key matched a specific state could be performed against the wrong key. This has been fixed by not only checking for the matching key tag but also the key algorithm. [GL #4878] 
Known Issues
- There are no new known issues with this release. See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.29
Feature Changes
- Tighten - max-recursion-queriesand add- max-query-restartsconfiguration statement.- There were cases when the - max-recursion-queriesquota was ineffective. It was possible to craft zones that would cause a resolver to waste resources by sending excessive queries while attempting to resolve a name. This has been addressed by correcting errors in the implementation of- max-recursion-queriesand by reducing the default value from 100 to 32.- In addition, a new - max-query-restartsconfiguration statement has been added, which limits the number of times a recursive server will follow CNAME or DNAME records before terminating resolution. This was previously a hard-coded limit of 16 but is now configurable with a default value of 11.- ISC would like to thank Huayi Duan, Marco Bearzi, Jodok Vieli, and Cagin Tanir from NetSec group, ETH Zurich for discovering and notifying us about the issue. [GL #4741] [GL !9283] 
- Raise the log level of priming failures. - When a priming query is complete, it was previously logged at level - DEBUG(1), regardless of success or failure. It is now logged to- NOTICEin the case of failure. [GL #3516] [GL !9251]
- Add a compatibility shim for older libuv versions (< 1.19.0) - The function uv_stream_get_write_queue_size() is supported only in relatively new versions of libuv (1.19.0 or higher). Provide a compatibility shim for this function so BIND 9 can be built in environments with older libuv versions. 
Bug Fixes
- Return SERVFAIL for a too long CNAME chain. - When following long CNAME chains, - namedwas returning NOERROR (along with a partial answer) instead of SERVFAIL, if the chain exceeded the maximum length. This has been fixed. [GL #4449] [GL !9204]
- Reconfigure catz member zones during - namedreconfiguration.- During a reconfiguration, - namedwasn’t reconfiguring catalog zones’ member zones. This has been fixed. [GL #4733]
- Update key lifetime and metadata after - dnssec-policyreconfiguration.- Adjust key state and timing metadata if - dnssec-policykey lifetime configuration is updated, so that it also affects existing keys. [GL #4677] [GL !9192]
- Fix generation of 6to4-self name expansion from IPv4 address. - The period between the most significant nibble of the encoded IPv4 address and the 2.0.0.2.IP6.ARPA suffix was missing, resulting in the wrong name being checked. This has been fixed. [GL #4766] [GL !9218] 
- dig +yamlwas producing unexpected and/or invalid YAML. output. [GL #4796] [GL !9214]
- SVBC ALPN text parsing failed to reject zero-length ALPN. [GL #4775] [GL !9210] 
- Fix false QNAME minimisation error being reported. - Remove the false positive - success resolvinglog message when QNAME minimisation is in effect and the final result is an NXDOMAIN. [GL #4784] [GL !9216]
- Fix dig +timeout argument when using +https. - The +timeout argument was not used on DoH connections. This has been fixed. [GL #4806] [GL !9161] 
Known Issues
- There are no new known issues with this release. See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.28
Security Fixes
- A malicious DNS client that sent many queries over TCP but never read the responses could cause a server to respond slowly or not at all for other clients. This has been fixed. (CVE-2024-0760) [GL #4481] 
- It is possible to craft excessively large resource records sets, which have the effect of slowing down database processing. This has been addressed by adding a configurable limit to the number of records that can be stored per name and type in a cache or zone database. The default is 100, which can be tuned with the new - max-records-per-typeoption. [GL #497] [GL #3405]- It is possible to craft excessively large numbers of resource record types for a given owner name, which has the effect of slowing down database processing. This has been addressed by adding a configurable limit to the number of records that can be stored per name and type in a cache or zone database. The default is 100, which can be tuned with the new - max-types-per-nameoption. (CVE-2024-1737) [GL #3403]- ISC would like to thank Toshifumi Sakaguchi who independently discovered and responsibly reported the issue to ISC. [GL #4548] 
- Validating DNS messages signed using the SIG(0) protocol (RFC 2931) could cause excessive CPU load, leading to a denial-of-service condition. Support for SIG(0) message validation was removed from this version of - named. (CVE-2024-1975) [GL #4480]
- Due to a logic error, lookups that triggered serving stale data and required lookups in local authoritative zone data could have resulted in an assertion failure. This has been fixed. (CVE-2024-4076) [GL #4507] 
- Potential data races were found in our DoH implementation, related to HTTP/2 session object management and endpoints set object management after reconfiguration. These issues have been fixed. [GL #4473] - ISC would like to thank Dzintars and Ivo from nic.lv for bringing this to our attention. 
- When looking up the NS records of parent zones as part of looking up DS records, it was possible for - namedto trigger an assertion failure if serve-stale was enabled. This has been fixed. [GL #4661]
Bug Fixes
- Command-line options for IPv4-only ( - named -4) and IPv6-only (- named -6) modes are now respected for zone- primaries,- also-notify, and- parental-agents. [GL #3472]
- An RPZ response’s SOA record TTL was set to 1 instead of the SOA TTL, if - add-soawas used. This has been fixed. [GL #3323]
- When a query related to zone maintenance (NOTIFY, SOA) timed out close to a view shutdown (triggered e.g. by - rndc reload),- namedcould crash with an assertion failure. This has been fixed. [GL #4719]
- The statistics channel counters that indicated the number of currently connected TCP IPv4/IPv6 clients were not properly adjusted in certain failure scenarios. This has been fixed. [GL #4742] 
- Some servers that could not be reached due to EHOSTDOWN or ENETDOWN conditions were incorrectly prioritized during server selection. These are now properly handled as unreachable. [GL #4736] 
- On some systems the libuv call may return an error code when sending a TCP reset for a connection, which triggers an assertion failure in - named. This error condition is now dealt with in a more graceful manner, by logging the incident and shutting down the connection. [GL #4708]
Known Issues
- There are no new known issues with this release. See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.27
New Features
- A new option - signatures-jitterhas been added to- dnssec-policyto allow signature expirations to be spread out over a period of time. [GL #4554]
Feature Changes
- DNSSEC signatures that are not valid because the current time falls outside the signature inception and expiration dates are skipped instead of causing an immediate validation failure. [GL #4586] 
Known Issues
- There are no new known issues with this release. See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.26
New Features
- The statistics channel now includes counters that indicate the number of currently connected TCP IPv4/IPv6 clients. [GL #4425] 
- Added RESOLVER.ARPA to the built in empty zones. [GL #4580] 
Bug Fixes
- Changes to - listen-onstatements were ignored on reconfiguration unless the port or interface address was changed, making it impossible to change a related listener transport type. That issue has been fixed.- ISC would like to thank Thomas Amgarten for bringing this issue to our attention. [GL #4518] [GL #4528] 
- A bug in the keymgr code unintentionally slowed down some DNSSEC key rollovers. This has been fixed. [GL #4552] 
- Some ISO 8601 durations were accepted erroneously, leading to shorter durations than expected. This has been fixed. [GL #4624] 
Known Issues
- There are no new known issues with this release. See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.25
Bug Fixes
- A regression in cache-cleaning code enabled memory use to grow significantly more quickly than before, until the configured - max-cache-sizelimit was reached. This has been fixed. [GL #4596]
- Using - rndc flushinadvertently caused cache cleaning to become less effective. This could ultimately lead to the configured- max-cache-sizelimit being exceeded and has now been fixed. [GL #4621]
- The logic for cleaning up expired cached DNS records was tweaked to be more aggressive. This change helps with enforcing - max-cache-ttland- max-ncache-ttlin a timely manner. [GL #4591]
- It was possible to trigger a use-after-free assertion when the overmem cache cleaning was initiated. This has been fixed. [GL #4595] - ISC would like to thank Jinmei Tatuya of Infoblox for bringing this issue to our attention. 
Known Issues
- There are no new known issues with this release. See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.24
Security Fixes
- Validating DNS messages containing a lot of DNSSEC signatures could cause excessive CPU load, leading to a denial-of-service condition. This has been fixed. (CVE-2023-50387) - ISC would like to thank Elias Heftrig, Haya Schulmann, Niklas Vogel, and Michael Waidner from the German National Research Center for Applied Cybersecurity ATHENE for bringing this vulnerability to our attention. [GL #4424] 
- Preparing an NSEC3 closest encloser proof could cause excessive CPU load, leading to a denial-of-service condition. This has been fixed. (CVE-2023-50868) [GL #4459] 
- Parsing DNS messages with many different names could cause excessive CPU load. This has been fixed. (CVE-2023-4408) - ISC would like to thank Shoham Danino from Reichman University, Anat Bremler-Barr from Tel-Aviv University, Yehuda Afek from Tel-Aviv University, and Yuval Shavitt from Tel-Aviv University for bringing this vulnerability to our attention. [GL #4234] 
- Specific queries could cause - namedto crash with an assertion failure when- nxdomain-redirectwas enabled. This has been fixed. (CVE-2023-5517) [GL #4281]
- A bad interaction between DNS64 and serve-stale could cause - namedto crash with an assertion failure, when both of these features were enabled. This has been fixed. (CVE-2023-5679) [GL #4334]
- Under certain circumstances, the DNS-over-TLS client code incorrectly attempted to process more than one DNS message at a time, which could cause - namedto crash with an assertion failure. This has been fixed. [GL #4487]
Bug Fixes
- The counters exported via the statistics channel were changed back to 64-bit signed values; they were being inadvertently truncated to unsigned 32-bit values since BIND 9.15.0. [GL #4467] 
Known Issues
- There are no new known issues with this release. See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.23
Note
The BIND 9.18.23 release was withdrawn after the discovery of a regression in a security fix in it during pre-release testing. ISC would like to acknowledge the assistance of Vinzenz Vogel and Daniel Stirnimann of SWITCH.
Notes for BIND 9.18.22
Note
The BIND 9.18.22 release was withdrawn after the discovery of a regression in a security fix in it during pre-release testing. ISC would like to acknowledge the assistance of Curtis Tuplin of SaskTel.
Notes for BIND 9.18.21
Removed Features
- Support for using AES as the DNS COOKIE algorithm ( - cookie-algorithm aes;) has been deprecated and will be removed in a future release. Please use the current default, SipHash-2-4, instead. [GL #4421]
- The - resolver-nonbackoff-triesand- resolver-retry-intervalstatements have been deprecated. Using them now causes a warning to be logged. [GL #4405]
Known Issues
- There are no new known issues with this release. See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.20
Feature Changes
- The IP addresses for B.ROOT-SERVERS.NET have been updated to 170.247.170.2 and 2801:1b8:10::b. [GL #4101] 
Bug Fixes
- If the unsigned version of an inline-signed zone contained DNSSEC records, it was incorrectly scheduled for resigning. This has been fixed. [GL #4350] 
- Looking up stale data from the cache did not take local authoritative data into account. This has been fixed. [GL #4355] 
- An assertion failure was triggered when - lock-filewas used at the same time as the- named -Xcommand-line option. This has been fixed. [GL #4386]
- The - lock-filefile was being removed when it should not have been, making the statement ineffective when- namedwas started three or more times. This has been fixed. [GL #4387]
Known Issues
- There are no new known issues with this release. See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.19
Security Fixes
- Previously, sending a specially crafted message over the control channel could cause the packet-parsing code to run out of available stack memory, causing - namedto terminate unexpectedly. This has been fixed. (CVE-2023-3341)- ISC would like to thank Eric Sesterhenn from X41 D-Sec GmbH for bringing this vulnerability to our attention. [GL #4152] 
- A flaw in the networking code handling DNS-over-TLS queries could cause - namedto terminate unexpectedly due to an assertion failure under significant DNS-over-TLS query load. This has been fixed. (CVE-2023-4236)- ISC would like to thank Robert Story from USC/ISI Root Server Operations for bringing this vulnerability to our attention. [GL #4242] 
Removed Features
- The - dnssec-must-be-secureoption has been deprecated and will be removed in a future release. [GL #4263]
Feature Changes
- If the - servercommand is specified,- nsupdatenow honors the- nsupdate -voption for SOA queries by sending both the UPDATE request and the initial query over TCP. [GL #1181]
Bug Fixes
- The value of the If-Modified-Since header in the statistics channel was not being correctly validated for its length, potentially allowing an authorized user to trigger a buffer overflow. Ensuring the statistics channel is configured correctly to grant access exclusively to authorized users is essential (see the - statistics-channelsblock definition and usage section). [GL #4124]- This issue was reported independently by Eric Sesterhenn of X41 D-Sec GmbH and Cameron Whitehead. 
- The Content-Length header in the statistics channel was lacking proper bounds checking. A negative or excessively large value could potentially trigger an integer overflow and result in an assertion failure. [GL #4125] - This issue was reported by Eric Sesterhenn of X41 D-Sec GmbH. 
- Several memory leaks caused by not clearing the OpenSSL error stack were fixed. [GL #4159] - This issue was reported by Eric Sesterhenn of X41 D-Sec GmbH. 
- The introduction of - krb5-subdomain-self-rhsand- ms-subdomain-self-rhsUPDATE policies accidentally caused- namedto return SERVFAIL responses to deletion requests for non-existent PTR and SRV records. This has been fixed. [GL #4280]
- The - stale-refresh-timefeature was mistakenly disabled when the server cache was flushed by- rndc flush. This has been fixed. [GL #4278]
- BIND’s memory consumption has been improved by implementing dedicated jemalloc memory arenas for sending buffers. This optimization ensures that memory usage is more efficient and better manages the return of memory pages to the operating system. [GL #4038] 
- Previously, partial writes in the TLS DNS code were not accounted for correctly, which could have led to DNS message corruption. This has been fixed. [GL #4255] 
Known Issues
- There are no new known issues with this release. See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.18
Feature Changes
- When a primary server for a zone responds to an SOA query, but the subsequent TCP connection required to transfer the zone is refused, that server is marked as temporarily unreachable. This now also happens if the TCP connection attempt times out, preventing too many zones from queuing up on an unreachable server and allowing the refresh process to move on to the next configured primary more quickly. [GL #4215] 
- The - dialupand- heartbeat-intervaloptions have been deprecated and will be removed in a future BIND 9 release. [GL #3700]
Bug Fixes
- Processing already-queued queries received over TCP could cause an assertion failure, when the server was reconfigured at the same time or the cache was being flushed. This has been fixed. [GL #4200] 
- Setting - dnssec-policyto- insecureprevented zones containing resource records with a TTL value larger than 86400 seconds (1 day) from being loaded. This has been fixed by ignoring the TTL values in the zone and using a value of 604800 seconds (1 week) as the maximum zone TTL in key rollover timing calculations. [GL #4032]
Known Issues
- There are no new known issues with this release. See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.17
Feature Changes
- If a response from an authoritative server has its RCODE set to FORMERR and contains an echoed EDNS COOKIE option that was present in the query, - namednow retries sending the query to the same server without an EDNS COOKIE option. [GL #4049]
- The - relaxedQNAME minimization mode now uses NS records. This reduces the number of queries- namedmakes when resolving, as it allows the non-existence of NS RRsets at non-referral nodes to be cached in addition to the normally cached referrals. [GL #3325]
Bug Fixes
- The ability to read HMAC-MD5 key files, which was accidentally lost in BIND 9.18.8, has been restored. [GL #3668] [GL #4154] 
- Several minor stability issues with the catalog zone implementation have been fixed. [GL #4132] [GL #4136] [GL #4171] 
Known Issues
- There are no new known issues with this release. See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.16
Security Fixes
- The overmem cleaning process has been improved, to prevent the cache from significantly exceeding the configured - max-cache-sizelimit. (CVE-2023-2828)- ISC would like to thank Shoham Danino from Reichman University, Anat Bremler-Barr from Tel-Aviv University, Yehuda Afek from Tel-Aviv University, and Yuval Shavitt from Tel-Aviv University for bringing this vulnerability to our attention. [GL #4055] 
- A query that prioritizes stale data over lookup triggers a fetch to refresh the stale data in cache. If the fetch is aborted for exceeding the recursion quota, it was possible for - namedto enter an infinite callback loop and crash due to stack overflow. This has been fixed. (CVE-2023-2911) [GL #4089]
New Features
- The system test suite can now be executed with pytest (along with pytest-xdist for parallel execution). [GL #3978] 
Removed Features
- TKEY mode 2 (Diffie-Hellman Exchanged Keying) is now deprecated, and will be removed in a future release. A warning will be logged when the - tkey-dhkeyoption is used in- named.conf. [GL #3905]
Bug Fixes
- BIND could get stuck on reconfiguration when a - listen-onstatement for HTTP is removed from the configuration. That has been fixed. [GL #4071]
- Previously, it was possible for a delegation from cache to be returned to the client after the - stale-answer-client-timeoutduration. This has been fixed. [GL #3950]
- BIND could allocate too big buffers when sending data via stream-based DNS transports, leading to increased memory usage. This has been fixed. [GL #4038] 
- When the - stale-answer-enableoption was enabled and the- stale-answer-client-timeoutoption was enabled and larger than 0,- namedpreviously allocated two slots from the- clients-per-querylimit for each client and failed to gradually auto-tune its value, as configured. This has been fixed. [GL #4074]
Known Issues
- There are no new known issues with this release. See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.15
Bug Fixes
- The - max-transfer-time-inand- max-transfer-idle-instatements have not had any effect since the BIND 9 networking stack was refactored in version 9.16. The missing functionality has been re-implemented and incoming zone transfers now time out properly when not progressing. [GL #4004]
- The read timeout in - rndcis now 60 seconds, matching the behavior in BIND 9.16 and earlier. It had previously been lowered to 30 seconds by mistake. [GL #4046]
- When the - ISC_R_INVALIDPROTO(- ENOPROTOOPT,- EPROTONOSUPPORT) error code is returned by libuv, it is now treated as a network failure: the server for which that error code is returned gets marked as broken and is not contacted again during a given resolution process. [GL #4005]
- When removing delegations from an opt-out range, empty-non-terminal NSEC3 records generated by those delegations were not cleaned up. This has been fixed. [GL #4027] 
- Log file rotation code did not clean up older versions of log files when the logging - channelhad an absolute path configured as a- filedestination. This has been fixed. [GL #3991]
Known Issues
- Sending NOTIFY messages silently fails when the source port specified in the - notify-sourcestatement is already in use. This can happen e.g. when multiple servers are configured as NOTIFY targets for a zone and some of them are unresponsive. This issue can be worked around by not specifying the source port for NOTIFY messages in the- notify-sourcestatement; note that source port configuration is already deprecated and will be removed altogether in a future release. [GL #4002]
- See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.14
Removed Features
- Zone type - delegation-only, and the- delegation-onlyand- root-delegation-onlystatements, have been deprecated. A warning is now logged when they are used.- These statements were created to address the SiteFinder controversy, in which certain top-level domains redirected misspelled queries to other sites instead of returning NXDOMAIN responses. Since top-level domains are now DNSSEC-signed, and DNSSEC validation is active by default, the statements are no longer needed. [GL #3953] 
Bug Fixes
- Several bugs which could cause - namedto crash during catalog zone processing have been fixed. [GL #3955] [GL #3968] [GL #3997]
- Previously, downloading large zones over TLS (XoT) from a primary could hang the transfer on the secondary, especially when the connection was unstable. This has been fixed. [GL #3867] 
- Performance of DNSSEC validation in zones with many DNSKEY records has been improved. [GL #3981] 
Known Issues
- There are no new known issues with this release. See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.13
New Features
- RPZ updates are now run on specialized “offload” threads to reduce the amount of time they block query processing on the main networking threads. This increases the responsiveness of - namedwhen RPZ updates are being applied after an RPZ zone has been successfully transferred. [GL #3190]
Feature Changes
- Catalog zone updates are now run on specialized “offload” threads to reduce the amount of time they block query processing on the main networking threads. This increases the responsiveness of - namedwhen catalog zone updates are being applied after a catalog zone has been successfully transferred. [GL #3881]
- libuv support for receiving multiple UDP messages in a single - recvmmsg()system call has been tweaked several times between libuv versions 1.35.0 and 1.40.0; the current recommended libuv version is 1.40.0 or higher. New rules are now in effect for running with a different version of libuv than the one used at compilation time. These rules may trigger a fatal error at startup:- Building against or running with libuv versions 1.35.0 and 1.36.0 is now a fatal error. 
- Running with libuv version higher than 1.34.2 is now a fatal error when - namedis built against libuv version 1.34.2 or lower.
- Running with libuv version higher than 1.39.0 is now a fatal error when - namedis built against libuv version 1.37.0, 1.38.0, 1.38.1, or 1.39.0.
 - This prevents the use of libuv versions that may trigger an assertion failure when receiving multiple UDP messages in a single system call. [GL #3840] 
Bug Fixes
- namedcould crash with an assertion failure when adding a new zone into the configuration file for a name which was already configured as a member zone for a catalog zone. This has been fixed. [GL #3911]
- When - namedstarts up, it sends a query for the DNSSEC key for each configured trust anchor to determine whether the key has changed. In some unusual cases, the query might depend on a zone for which the server is itself authoritative, and would have failed if it were sent before the zone was fully loaded. This has now been fixed by delaying the key queries until all zones have finished loading. [GL #3673]
Known Issues
- There are no new known issues with this release. See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.12
Removed Features
- Specifying a - portwhen configuring source addresses (i.e., as an argument to- query-source,- query-source-v6,- transfer-source,- transfer-source-v6,- notify-source,- notify-source-v6,- parental-source, or- parental-source-v6, or in the- sourceor- source-v6arguments to- primaries,- parental-agents,- also-notify, or- catalog-zones) has been deprecated. In addition, the- use-v4-udp-ports,- use-v6-udp-ports,- avoid-v4-udp-ports, and- avoid-v6-udp-portsoptions have also been deprecated.- Warnings are now logged when any of these options are encountered in - named.conf. In a future release, they will be made nonfunctional. [GL #3781]
Bug Fixes
- A constant stream of zone additions and deletions via - rndc reconfigcould cause increased memory consumption due to delayed cleaning of view memory. This has been fixed. [GL #3801]
- The speed of the message digest algorithms (MD5, SHA-1, SHA-2), and of NSEC3 hashing, has been improved. [GL #3795] 
- Pointing - parental-agentsto a resolver did not work because the RD bit was not set on DS requests. This has been fixed. [GL #3783]
- Building BIND 9 failed when the - --enable-dnsrpsswitch for- ./configurewas used. This has been fixed. [GL #3827]
Known Issues
- There are no new known issues with this release. See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.11
Security Fixes
- An UPDATE message flood could cause - namedto exhaust all available memory. This flaw was addressed by adding a new- update-quotaoption that controls the maximum number of outstanding DNS UPDATE messages that- namedcan hold in a queue at any given time (default: 100). (CVE-2022-3094)- ISC would like to thank Rob Schulhof from Infoblox for bringing this vulnerability to our attention. [GL #3523] 
- namedcould crash with an assertion failure when an RRSIG query was received and- stale-answer-client-timeoutwas set to a non-zero value. This has been fixed. (CVE-2022-3736)- ISC would like to thank Borja Marcos from Sarenet (with assistance by Iratxe Niño from Fundación Sarenet) for bringing this vulnerability to our attention. [GL #3622] 
- namedrunning as a resolver with the- stale-answer-client-timeoutoption set to any value greater than- 0could crash with an assertion failure, when the- recursive-clientssoft quota was reached. This has been fixed. (CVE-2022-3924)- ISC would like to thank Maksym Odinintsev from AWS for bringing this vulnerability to our attention. [GL #3619] 
New Features
- The new - update-quotaoption can be used to control the number of simultaneous DNS UPDATE messages that can be processed to update an authoritative zone on a primary server, or forwarded to the primary server by a secondary server. The default is 100. A new statistics counter has also been added to record events when this quota is exceeded, and the version numbers for the XML and JSON statistics schemas have been updated. [GL #3523]
Removed Features
- The Differentiated Services Code Point (DSCP) feature in BIND has been non-operational since the new Network Manager was introduced in BIND 9.16. It is now marked as obsolete, and vestigial code implementing it has been removed. Configuring DSCP values in - named.confnow causes a warning to be logged. [GL #3773]
Feature Changes
- The catalog zone implementation has been optimized to work with hundreds of thousands of member zones. [GL #3212] [GL #3744] 
Bug Fixes
- A rare assertion failure was fixed in outgoing TCP DNS connection handling. [GL #3178] [GL #3636] 
- Large zone transfers over TLS (XoT) could fail. This has been fixed. [GL #3772] 
- In addition to a previously fixed bug, another similar issue was discovered where quotas could be erroneously reached for servers, including any configured forwarders, resulting in SERVFAIL answers being sent to clients. This has been fixed. [GL #3752] 
- In certain query resolution scenarios (e.g. when following CNAME records), - namedconfigured to answer from stale cache could return a SERVFAIL response despite a usable, non-stale answer being present in the cache. This has been fixed. [GL #3678]
- When an outgoing request timed out, - namedwould retry up to three times with the same server instead of trying the next available name server. This has been fixed. [GL #3637]
- Recently used ADB names and ADB entries (IP addresses) could get cleaned when ADB was under memory pressure. To mitigate this, only actual ADB names and ADB entries are now counted (excluding internal memory structures used for “housekeeping”) and recently used (<= 10 seconds) ADB names and entries are excluded from the overmem memory cleaner. [GL #3739] 
- The “Prohibited” Extended DNS Error was inadvertently set in some NOERROR responses. This has been fixed. [GL #3743] 
- Previously, TLS session resumption could have led to handshake failures when client certificates were used for authentication (Mutual TLS). This has been fixed. [GL #3725] 
Known Issues
- There are no new known issues with this release. See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.10
Feature Changes
- To reduce unnecessary memory consumption in the cache, NXDOMAIN records are no longer retained past the normal negative cache TTL, even if - stale-cache-enableis set to- yes. [GL #3386]
- The - auto-dnssecoption has been deprecated and will be removed in a future BIND 9.19.x release. Please migrate to- dnssec-policy. [GL #3667]
- The - coresize,- datasize,- files, and- stacksizeoptions have been deprecated. The limits these options set should be enforced externally, either by manual configuration (e.g. using- ulimit) or via the process supervisor (e.g.- systemd). [GL #3676]
- Setting alternate local addresses for inbound zone transfers has been deprecated. The relevant options ( - alt-transfer-source,- alt-transfer-source-v6, and- use-alt-transfer-source) will be removed in a future BIND 9.19.x release. [GL #3694]
- The number of HTTP headers allowed in requests sent to - named’s statistics channel has been increased from 10 to 100, to accommodate some browsers that send more than 10 headers by default. [GL #3670]
Bug Fixes
- namedcould crash due to an assertion failure when an HTTP connection to the statistics channel was closed prematurely (due to a connection error, shutdown, etc.). This has been fixed. [GL #3693]
- When a catalog zone was removed from the configuration, in some cases a dangling pointer could cause the - namedprocess to crash. This has been fixed. [GL #3683]
- When a zone was deleted from a server, a key management object related to that zone was inadvertently kept in memory and only released upon shutdown. This could lead to constantly increasing memory use on servers with a high rate of changes affecting the set of zones being served. This has been fixed. [GL #3727] 
- TLS configuration for primary servers was not applied for zones that were members of a catalog zone. This has been fixed. [GL #3638] 
- In certain cases, - namedwaited for the resolution of outstanding recursive queries to finish before shutting down. This was unintended and has been fixed. [GL #3183]
- hostand- nslookupcommand-line options setting the custom TCP/UDP port to use were ignored for ANY queries (which are sent over TCP). This has been fixed. [GL #3721]
- The - zone <name>/<class>: final reference detachedlog message was moved from the INFO log level to the DEBUG(1) log level to prevent the- named-checkzonetool from superfluously logging this message in non-debug mode. [GL #3707]
Known Issues
- There are no new known issues with this release. See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.9
Bug Fixes
- A crash was fixed that happened when a - dnssec-policyzone that used NSEC3 was reconfigured to enable- inline-signing. [GL #3591]
- In certain resolution scenarios, quotas could be erroneously reached for servers, including any configured forwarders, resulting in SERVFAIL answers being sent to clients. This has been fixed. [GL #3598] 
- rpz-iprules in- response-policyzones could be ineffective in some cases if a query had the CD (Checking Disabled) bit set to 1. This has been fixed. [GL #3247]
- Previously, if Internet connectivity issues were experienced during the initial startup of - named, a BIND resolver with- dnssec-validationset to- autocould enter into a state where it would not recover without stopping- named, manually deleting the- managed-keys.bindand- managed-keys.bind.jnlfiles, and starting- namedagain. This has been fixed. [GL #2895]
- The statistics counter representing the current number of clients awaiting recursive resolution results ( - RecursClients) could overflow in certain resolution scenarios. This has been fixed. [GL #3584]
- Previously, the port in remote servers such as in - primariesand- parental-agentscould be wrongly configured because of an inheritance bug. This has been fixed. [GL #3627]
- Previously, BIND failed to start on Solaris-based systems with hundreds of CPUs. This has been fixed. [GL #3563] 
- When a DNS resource record’s TTL value was equal to the resolver’s configured - prefetch“eligibility” value, the record was erroneously not treated as eligible for prefetching. This has been fixed. [GL #3603]
Known Issues
- There are no new known issues with this release. See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.8
Known Issues
- Upgrading from BIND 9.16.32, 9.18.6, or any older version may require a manual configuration change. The following configurations are affected: - type primaryzones configured with- dnssec-policybut without either- allow-updateor- update-policy,
- type secondaryzones configured with- dnssec-policy.
 - In these cases please add - inline-signing yes;to the individual zone configuration(s). Without applying this change,- namedwill fail to start. For more details, see https://kb.isc.org/docs/dnssec-policy-requires-dynamic-dns-or-inline-signing
- BIND 9.18 does not support dynamic update forwarding (see - allow-update-forwarding) in conjuction with zone transfers over TLS (XoT). [GL #3512]
- See above for a list of all known issues affecting this BIND 9 branch. 
New Features
- Support for parsing and validating the - dohpathservice parameter in SVCB records was added. [GL #3544]
- namednow logs the supported cryptographic algorithms during startup and in the output of- named -V. [GL #3541]
- The - recursion not availableand- query (cache) '...' deniedlog messages were extended to include the name of the ACL that caused a given query to be denied. [GL #3587]
Feature Changes
- The ability to use PKCS#11 via engine_pkcs11 has been restored, by using only deprecated APIs in OpenSSL 3.0.0. BIND 9 needs to be compiled with - -DOPENSSL_API_COMPAT=10100specified in the CFLAGS environment variable at compile time. [GL #3578]
Bug Fixes
- An assertion failure was fixed in - namedthat was caused by aborting the statistics channel connection while sending statistics data to the client. [GL #3542]
- Changing just the TSIG key names for primaries in catalog zones’ member zones was not effective. This has been fixed. [GL #3557] 
Notes for BIND 9.18.7
Security Fixes
- Previously, there was no limit to the number of database lookups performed while processing large delegations, which could be abused to severely impact the performance of - namedrunning as a recursive resolver. This has been fixed. (CVE-2022-2795)- ISC would like to thank Yehuda Afek from Tel-Aviv University and Anat Bremler-Barr & Shani Stajnrod from Reichman University for bringing this vulnerability to our attention. [GL #3394] 
- When an HTTP connection was reused to request statistics from the stats channel, the content length of successive responses could grow in size past the end of the allocated buffer. This has been fixed. (CVE-2022-2881) [GL #3493] 
- Memory leaks in code handling Diffie-Hellman (DH) keys were fixed that could be externally triggered, when using TKEY records in DH mode with OpenSSL 3.0.0 and later versions. (CVE-2022-2906) [GL #3491] 
- namedrunning as a resolver with the- stale-answer-client-timeoutoption set to- 0could crash with an assertion failure, when there was a stale CNAME in the cache for the incoming query. This has been fixed. (CVE-2022-3080) [GL #3517]
- Memory leaks were fixed that could be externally triggered in the DNSSEC verification code for the EdDSA algorithm. (CVE-2022-38178) [GL #3487] 
Feature Changes
- Response Rate Limiting (RRL) code now treats all QNAMEs that are subject to wildcard processing within a given zone as the same name, to prevent circumventing the limits enforced by RRL. [GL #3459] 
- Zones using - dnssec-policynow require dynamic DNS or- inline-signingto be configured explicitly. [GL #3381]
- When reconfiguring - dnssec-policyfrom using NSEC with an NSEC-only DNSKEY algorithm (e.g. RSASHA1) to a policy that uses NSEC3, BIND 9 no longer fails to sign the zone; instead, it keeps using NSEC until the offending DNSKEY records have been removed from the zone, then switches to using NSEC3. [GL #3486]
- A backward-compatible approach was implemented for encoding internationalized domain names (IDN) in - digand converting the domain to IDNA2008 form; if that fails, BIND tries an IDNA2003 conversion. [GL #3485]
Bug Fixes
- A serve-stale bug was fixed, where BIND would try to return stale data from cache for lookups that received duplicate queries or queries that would be dropped. This bug resulted in premature SERVFAIL responses, and has now been resolved. [GL #2982] 
Known Issues
- There are no new known issues with this release. See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.6
Feature Changes
- The DNSSEC algorithms RSASHA1 and NSEC3RSASHA1 are now automatically disabled on systems where they are disallowed by the security policy (e.g. Red Hat Enterprise Linux 9). Primary zones using those algorithms need to be migrated to new algorithms prior to running on these systems, as graceful migration to different DNSSEC algorithms is not possible when RSASHA1 is disallowed by the operating system. [GL #3469] 
- Log messages related to fetch limiting have been improved to provide more complete information. Specifically, the final counts of allowed and spilled fetches are now logged before the counter object is destroyed. [GL #3461] 
Bug Fixes
- When running as a validating resolver forwarding all queries to another resolver, - namedcould crash with an assertion failure. These crashes occurred when the configured forwarder sent a broken DS response and- namedfailed its attempts to find a proper one instead. This has been fixed. [GL #3439]
- Non-dynamic zones that inherit - dnssec-policyfrom the- viewor- optionsblocks were not marked as inline-signed and therefore never scheduled to be re-signed. This has been fixed. [GL #3438]
- The old - max-zone-ttlzone option was meant to be superseded by the- max-zone-ttloption in- dnssec-policy; however, the latter option was not fully effective. This has been corrected: zones no longer load if they contain TTLs greater than the limit configured in- dnssec-policy. For zones with both the old- max-zone-ttloption and- dnssec-policyconfigured, the old option is ignored, and a warning is generated. [GL #2918]
- rndc dumpdb -expiredwas fixed to include expired RRsets, even if- stale-cache-enableis set to- noand the cache-cleaning time window has passed. [GL #3462]
Known Issues
- There are no new known issues with this release. See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.5
Feature Changes
- The - dnssec-signzone -Hdefault value has been changed to 0 additional NSEC3 iterations. This change aligns the- dnssec-signzonedefault with the default used by the- dnssec-policyfeature. At the same time, documentation about NSEC3 has been aligned with the Best Current Practice. [GL #3395]
Bug Fixes
- An assertion failure caused by a TCP connection closing between a connect (or accept) and a read from a socket has been fixed. [GL #3400] 
- When grafting non-delegated namespace onto delegated namespace, - synth-from-dnsseccould incorrectly synthesize non-existence of records within the non-delegated namespace using NSEC records from higher zones. [GL #3402]
- Previously, - namedimmediately returned a SERVFAIL response to the client when it received a FORMERR response from an authoritative server during recursive resolution. This has been fixed:- namedacting as a resolver now attempts to contact other authoritative servers for a given domain when it receives a FORMERR response from one of them. [GL #3152]
- Previously, - rndc reconfigdid not pick up changes to- endpointsstatements in- httpblocks. This has been fixed. [GL #3415]
- It was possible for a catalog zone consumer to process a catalog zone member zone when there was a configured pre-existing forward-only forward zone with the same name. This has been fixed. [GL #2506] 
Known Issues
- There are no new known issues with this release. See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.4
Feature Changes
- New - dnssec-policyconfiguration checks have been added to detect unusual policies, such as missing KSK and/or ZSK and too-short key lifetimes and re-sign periods. [GL #1611]
Bug Fixes
- The - fetches-per-serverquota is designed to adjust itself downward automatically when an authoritative server times out too frequently. Due to a coding error, that adjustment was applied incorrectly, so that the quota for a congested server was always set to 1. This has been fixed. [GL #3327]
- DNSSEC-signed catalog zones were not being processed correctly. This has been fixed. [GL #3380] 
- Key files were updated every time the - dnssec-policykey manager ran, whether the metadata had changed or not.- namednow checks whether changes were applied before writing out the key files. [GL #3302]
Known Issues
- There are no new known issues with this release. See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.3
Security Fixes
- Previously, TLS socket objects could be destroyed prematurely, which triggered assertion failures in - namedinstances serving DNS-over-HTTPS (DoH) clients. This has been fixed.- ISC would like to thank Thomas Amgarten from arcade solutions ag for bringing this vulnerability to our attention. (CVE-2022-1183) [GL #3216] 
Known Issues
- According to RFC 8310, Section 8.1, the - Subjectfield MUST NOT be inspected when verifying a remote certificate while establishing a DNS-over-TLS connection. Only- subjectAltNamemust be checked instead. Unfortunately, some quite old versions of cryptographic libraries might lack the ability to ignore the- Subjectfield. This should have minimal production-use consequences, as most of the production-ready certificates issued by certificate authorities will have- subjectAltNameset. In such cases, the- Subjectfield is ignored. Only old platforms are affected by this, e.g. those supplied with OpenSSL versions older than 1.1.1. [GL #3163]
- See above for a list of all known issues affecting this BIND 9 branch. 
New Features
- Catalog Zones schema version 2, as described in the “DNS Catalog Zones” IETF draft version 5 document, is now supported by - named. All of the previously supported BIND-specific catalog zone custom properties (- primaries,- allow-query, and- allow-transfer), as well as the new Change of Ownership (- coo) property, are now implemented. Schema version 1 is still supported, with some additional validation rules applied from schema version 2: for example, the- versionproperty is mandatory, and a member zone PTR RRset must not contain more than one record. In the event of a validation error, a corresponding error message is logged to help with diagnosing the problem. [GL #3221] [GL #3222] [GL #3223] [GL #3224] [GL #3225]
- Support DNS Extended Errors (RFC 8914) - Stale Answerand- Stale NXDOMAIN Answerwhen stale answers are returned from cache. [GL #2267]
- Add support for remote TLS certificate verification, both to - namedand- dig, making it possible to implement Strict and Mutual TLS authentication, as described in RFC 9103, Section 9.3. [GL #3163]
Bug Fixes
- Previously, CDS and CDNSKEY DELETE records were removed from the zone when configured with the - auto-dnssec maintain;option. This has been fixed. [GL #2931]
Notes for BIND 9.18.2
New Features
- Add a new configuration option - reuseportto disable load balancing on sockets in situations where processing of Response Policy Zones (RPZ), Catalog Zones, or large zone transfers can cause service disruptions. See the BIND 9 ARM for more detail. [GL #3249]
Bug Fixes
- Previously, zone maintenance DNS queries retried forever if the destination server was unreachable. These queries included outgoing NOTIFY messages, refresh SOA queries, parental DS checks, and stub zone NS queries. For example, if a zone had any nameservers with IPv6 addresses and a secondary server without IPv6 connectivity, that server would keep trying to send a growing amount of NOTIFY traffic over IPv6. This futile traffic was not logged. This excessive retry behavior has been fixed. [GL #3242] 
- A number of crashes and hangs which could be triggered in - digwere identified and addressed. [GL #3020] [GL #3128] [GL #3145] [GL #3184] [GL #3205] [GL #3244] [GL #3248]
- Invalid - dnssec-policydefinitions, where the defined keys did not cover both KSK and ZSK roles for a given algorithm, were being accepted. These are now checked, and the- dnssec-policyis rejected if both roles are not present for all algorithms in use. [GL #3142]
- Handling of TCP write timeouts has been improved to track the timeout for each TCP write separately, leading to a faster connection teardown in case the other party is not reading the data. [GL #3200] 
Known Issues
- There are no new known issues with this release. See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.1
Security Fixes
- The rules for acceptance of records into the cache have been tightened to prevent the possibility of poisoning if forwarders send records outside the configured bailiwick. (CVE-2021-25220) - ISC would like to thank Xiang Li, Baojun Liu, and Chaoyi Lu from Network and Information Security Lab, Tsinghua University, and Changgen Zou from Qi An Xin Group Corp. for bringing this vulnerability to our attention. [GL #2950] 
- TCP connections with - keep-response-orderenabled could leave the TCP sockets in the- CLOSE_WAITstate when the client did not properly shut down the connection. (CVE-2022-0396) [GL #3112]
- Lookups involving a DNAME could trigger an assertion failure when - synth-from-dnssecwas enabled (which is the default). (CVE-2022-0635)- ISC would like to thank Vincent Levigneron from AFNIC for bringing this vulnerability to our attention. [GL #3158] 
- When chasing DS records, a timed-out or artificially delayed fetch could cause - namedto crash while resuming a DS lookup. (CVE-2022-0667) [GL #3129]
Feature Changes
- The DLZ API has been updated: EDNS Client-Subnet (ECS) options sent by a client are now included in the client information sent to DLZ modules when processing queries. [GL #3082] 
- DEBUG(1)-level messages were added when starting and ending the BIND 9 task-exclusive mode that stops normal DNS operation (e.g. for reconfiguration, interface scans, and other events that require exclusive access to a shared resource). [GL #3137] 
- The limit on the number of simultaneously processed pipelined DNS queries received over TCP has been removed. Previously, it was capped at 23 queries processed at the same time. [GL #3141] 
Bug Fixes
- A failed view configuration during a - namedreconfiguration procedure could cause inconsistencies in BIND internal structures, causing a crash or other unexpected errors. This has been fixed. [GL #3060]
- Previously, - namedlogged a “quota reached” message when it hit its hard quota on the number of connections. That message was accidentally removed but has now been restored. [GL #3125]
- The - max-transfer-time-outand- max-transfer-idle-outoptions were not implemented when the BIND 9 networking stack was refactored in 9.16. The missing functionality has been re-implemented and outgoing zone transfers now time out properly when not progressing. [GL #1897]
- TCP connections could hang indefinitely if the other party did not read sent data, causing the TCP write buffers to fill. This has been fixed by adding a “write” timer. Connections that are hung while writing now time out after the - tcp-idle-timeoutperiod has elapsed. [GL #3132]
- Client TCP connections are now closed immediately when data received cannot be parsed as a valid DNS request. [GL #3149] 
- The statistics counter representing the current number of clients awaiting recursive resolution results ( - RecursClients) could be miscalculated in certain resolution scenarios, potentially causing the value of the counter to drop below zero. This has been fixed. [GL #3147]
- An error in the processing of the - blackholeACL could cause some DNS requests sent by- namedto fail - for example, zone transfer requests and SOA refresh queries - if the destination address or prefix was specifically excluded from the ACL using- !, or if the ACL was set to- none. This has now been fixed.- blackholeworked correctly when it was left unset, or if only positive-match elements were included. [GL #3157]
- Build errors were introduced in some DLZ modules due to an incomplete change in the previous release. This has been fixed. [GL #3111] 
Known Issues
- There are no new known issues with this release. See above for a list of all known issues affecting this BIND 9 branch. 
Notes for BIND 9.18.0
Note
This section only lists changes since BIND 9.16.25, the most recent release on the previous stable branch of BIND before the publication of BIND 9.18.0.
Known Issues
- rndchas been updated to use the new BIND network manager API. As the network manager currently has no support for UNIX-domain sockets, those cannot now be used with- rndc. This will be addressed in a future release, either by restoring UNIX-domain socket support or by formally declaring them to be obsolete in the control channel. [GL #1759]
- See above for a list of all known issues affecting this BIND 9 branch. 
New Features
- namednow supports securing DNS traffic using Transport Layer Security (TLS). TLS is used by both DNS over TLS (DoT) and DNS over HTTPS (DoH).- namedcan use either a certificate provided by the user or an ephemeral certificate generated automatically upon startup. The- tlsblock allows fine-grained control over TLS parameters. [GL #1840] [GL #2795] [GL #2796]- For debugging purposes, - namedlogs TLS pre-master secrets when the- SSLKEYLOGFILEenvironment variable is set. This enables troubleshooting of issues with encrypted traffic. [GL #2723]
- Support for DNS over TLS (DoT) has been added to - named. Network interfaces for DoT are configured using the existing listen-on directive, while TLS parameters are configured using the new- tlsblock. [GL #1840]- namedsupports zone transfers over TLS (XFR-over-TLS, XoT) for both incoming and outgoing zone transfers.- Incoming zone transfers over TLS are enabled by adding the - tlskeyword, followed by either the name of a previously configured- tlsblock or the string- ephemeral, to the addresses included in- primarieslists. [GL #2392]- Similarly, the - allow-transferoption was extended to accept additional- portand- transportparameters, to further restrict outgoing zone transfers to a particular port and/or DNS transport protocol. [GL #2776]- Note that zone transfers over TLS (XoT) require the - dotApplication-Layer Protocol Negotiation (ALPN) token to be selected in the TLS handshake, as required by RFC 9103 section 7.1. This might cause issues with non-compliant XoT servers. [GL #2794]- The - digtool is now able to send DoT queries (- +tlsoption). [GL #1840]- There is currently no support for forwarding DNS queries via DoT. 
- Support for DNS over HTTPS (DoH) has been added to - named. Both TLS-encrypted and unencrypted connections are supported (the latter may be used to offload encryption to other software). Network interfaces for DoH are configured using the existing listen-on directive, while TLS parameters are configured using the new- tlsblock and HTTP parameters are configured using the new- httpblock. [GL #1144] [GL #2472]- Server-side quotas on both the number of concurrent DoH connections and the number of active HTTP/2 streams per connection can be configured using the global - http-listener-clientsand- http-streams-per-connectionoptions, or the- listener-clientsand- streams-per-connectionparameters in an- http block. [GL #2809]- The - digtool is now able to send DoH queries (- +httpsoption). [GL #1641]- There is currently no support for forwarding DNS queries via DoH. - DoH support can be disabled at compile time using a new build-time option, - --disable-doh. This allows BIND 9 to be built without the libnghttp2 library. [GL #2478]
- A new logging category, - rpz-passthru, was added, which allows RPZ passthru actions to be logged into a separate channel. [GL #54]
- A new option, - nsdname-wait-recurse, has been added to the- response-policyclause in the configuration file. When set to- no, RPZ NSDNAME rules are only applied if the authoritative nameservers for the query name have been looked up and are present in the cache. If this information is not present, the RPZ NSDNAME rules are ignored, but the information is looked up in the background and applied to subsequent queries. The default is- yes, meaning that RPZ NSDNAME rules should always be applied, even if the information needs to be looked up first. [GL #1138]
- Support for HTTPS and SVCB record types now also includes ADDITIONAL section processing for these record types. [GL #1132] 
- New configuration options, - tcp-receive-buffer,- tcp-send-buffer,- udp-receive-buffer, and- udp-send-buffer, have been added. These options allow the operator to fine-tune the receiving and sending buffers in the operating system. On busy servers, increasing the size of the receive buffers can prevent the server from dropping packets during short traffic spikes, and decreasing it can prevent the server from becoming clogged with queries that are too old and have already timed out. [GL #2313]
- New finer-grained - update-policyrule types,- krb5-subdomain-self-rhsand- ms-subdomain-self-rhs, were added. These rule types restrict updates to SRV and PTR records so that their content can only match the machine name embedded in the Kerberos principal making the change. [GL #481]
- Per-type record count limits can now be specified in - update-policystatements, to limit the number of records of a particular type that can be added to a domain name via dynamic update. [GL #1657]
- Support for OpenSSL 3.0 APIs was added. [GL #2843] [GL #3057] 
- Extended DNS Error Code 18 - Prohibited (see RFC 8914 section 4.19) is now set if query access is denied to the specific client. [GL #1836] 
- ipv4only.arpais now served when DNS64 is configured. [GL #385]
- digcan now report the DNS64 prefixes in use (- +dns64prefix). This is useful when the host on which- digis run is behind an IPv6-only link, using DNS64/NAT64 or 464XLAT for IPv4aaS (IPv4 as a Service). [GL #1154]
- digoutput now includes the transport protocol used (UDP, TCP, TLS, HTTPS). [GL #1144] [GL #1816]
- dig +qid=<num>allows the user to specify a particular query ID for testing purposes. [GL #1851]
Removed Features
- Support for the - mapzone file format (- masterfile-format map;) has been removed. Users relying on the- mapformat are advised to convert their zones to the- rawformat with- named-compilezoneand change the configuration appropriately prior to upgrading BIND 9. [GL #2882]
- Old-style Dynamically Loadable Zones (DLZ) drivers that had to be enabled in - namedat build time have been removed. New-style DLZ modules should be used as a replacement. [GL #2814]
- Support for compiling and running BIND 9 natively on Windows has been completely removed. The last stable release branch that has working Windows support is BIND 9.16. [GL #2690] 
- Native PKCS#11 support has been removed. [GL #2691] - When built against OpenSSL 1.x, BIND 9 now uses engine_pkcs11 for PKCS#11. engine_pkcs11 is an OpenSSL engine which is part of the OpenSC project. - As support for so-called “engines” was deprecated in OpenSSL 3.x, compiling BIND 9 against an OpenSSL 3.x build which does not retain support for deprecated APIs makes it impossible to use PKCS#11 in BIND 9. A replacement for engine_pkcs11 which employs the new “provider” approach introduced in OpenSSL 3.x is in the making. [GL #2843] 
- The utilities - dnssec-checkds,- dnssec-coverage, and- dnssec-keymgrhave been removed from the BIND distribution, as well as the- iscPython package. DNSSEC features formerly provided by these utilities are now integrated into- named. See the- dnssec-policyconfiguration option for more details.- An archival version of the Python utilities has been moved to the repository https://gitlab.isc.org/isc-projects/dnssec-keymgr/. Please note these tools are no longer supported by ISC. 
- Since the old socket manager API has been removed, “socketmgr” statistics are no longer reported by the - statistics-channels. [GL #2926]
- The - glue-cacheoption has been marked as deprecated. The glue cache feature still works and will be permanently enabled in a future release. [GL #2146]
- A number of non-working configuration options that had been marked as obsolete in previous releases have now been removed completely. Using any of the following options is now considered a configuration failure: - acache-cleaning-interval,- acache-enable,- additional-from-auth,- additional-from-cache,- allow-v6-synthesis,- cleaning-interval,- dnssec-enable,- dnssec-lookaside,- filter-aaaa,- filter-aaaa-on-v4,- filter-aaaa-on-v6,- geoip-use-ecs,- lwres,- max-acache-size,- nosit-udp-size,- queryport-pool-ports,- queryport-pool-updateinterval,- request-sit,- sit-secret,- support-ixfr,- use-queryport-pool,- use-ixfr. [GL #1086]
- The - digoption- +unexpectedhas been removed. [GL #2140]
- IPv6 sockets are now explicitly restricted to sending and receiving IPv6 packets only. As this breaks the - +mappedoption for- dig, the option has been removed. [GL #3093]
- Disable and disallow static linking of BIND 9 binaries and libraries as BIND 9 modules require - dlopen()support and static linking also prevents using security features like read-only relocations (RELRO) or address space layout randomization (ASLR) which are important for programs that interact with the network and process arbitrary user input. [GL #1933]
- The - --with-gperftools-profiler- configureoption was removed. To use the gperftools profiler, the- HAVE_GPERFTOOLS_PROFILERmacro now needs to be manually set in- CFLAGSand- -lprofilerneeds to be present in- LDFLAGS. [GL !4045]
Feature Changes
- Aggressive Use of DNSSEC-Validated Cache ( - synth-from-dnssec, see RFC 8198) is now enabled by default again, after having been disabled in BIND 9.14.8. The implementation of this feature was reworked to achieve better efficiency and tuned to ignore certain types of broken NSEC records. Negative answer synthesis is currently only supported for zones using NSEC. [GL #1265]
- The default NSEC3 parameters for - dnssec-policywere updated to no extra SHA-1 iterations and no salt (- NSEC3PARAM 1 0 0 -). This change is in line with the latest NSEC3 recommendations. [GL #2956]
- The default for - dnssec-dnskey-kskonlywas changed to- yes. This means that DNSKEY, CDNSKEY, and CDS RRsets are now only signed with the KSK by default. The additional signatures prepared using the ZSK when the option is set to- noadd to the DNS response payload without offering added value. [GL #1316]
- dnssec-cdsnow only generates SHA-2 DS records by default and avoids copying deprecated SHA-1 records from a child zone to its delegation in the parent. If the child zone does not publish SHA-2 CDS records,- dnssec-cdswill generate them from the CDNSKEY records. The- -a algorithmoption now affects the process of generating DS digest records from both CDS and CDNSKEY records. Thanks to Tony Finch. [GL #2871]
- Previously, - namedaccepted FORMERR responses both with and without an OPT record, as an indication that a given server did not support EDNS. To implement full compliance with RFC 6891, only FORMERR responses without an OPT record are now accepted. This intentionally breaks communication with servers that do not support EDNS and that incorrectly echo back the query message with the RCODE field set to FORMERR and the QR bit set to 1. [GL #2249]
- The question section is now checked when processing AXFR, IXFR, and SOA replies while transferring a zone in. [GL #1683] 
- DNS Flag Day 2020: the EDNS buffer size probing code, which made the resolver adjust the EDNS buffer size used for outgoing queries based on the successful query responses and timeouts observed, was removed. The resolver now always uses the EDNS buffer size set in - edns-udp-sizefor all outgoing queries. [GL #2183]
- Keeping stale answers in cache ( - stale-cache-enable) has been disabled by default. [GL #1712]
- Overall memory use by - namedhas been optimized and significantly reduced, especially for resolver workloads. [GL #2398] [GL #3048]
- Memory allocation is now based on the memory allocation API provided by the jemalloc library, on platforms where it is available. Use of this library is now recommended when building BIND 9; although it is optional, it is enabled by default. [GL #2433] 
- Internal data structures maintained for each cache database are now grown incrementally when they need to be expanded. This helps maintain a steady response rate on a loaded resolver while these internal data structures are resized. [GL #2941] 
- The interface handling code has been refactored to use fewer resources, which should lead to less memory fragmentation and better startup performance. [GL #2433] 
- When reporting zone types in the statistics channel, the terms - primaryand- secondaryare now used instead of- masterand- slave, respectively. [GL #1944]
- The - rndc nta -dumpand- rndc secrootscommands now both include- validate-exceptentries when listing negative trust anchors. These are indicated by the keyword- permanentin place of the expiry date. [GL #1532]
- The output of - rndc serve-stale statushas been clarified. It now explicitly reports whether retention of stale data in the cache is enabled (- stale-cache-enable), and whether returning such data in responses is enabled (- stale-answer-enable). [GL #2742]
- Previously, using - dig +bufsize=0had the side effect of disabling EDNS, and there was no way to test the remote server’s behavior when it had received a packet with EDNS0 buffer size set to 0. This is no longer the case;- dig +bufsize=0now sends a DNS message with EDNS version 0 and buffer size set to 0. To disable EDNS, use- dig +noedns. [GL #2054]
- BIND 9 binaries which are neither daemons nor administrative programs were moved to - $bindir. Only- ddns-confgen,- named,- rndc,- rndc-confgen, and- tsig-confgenwere left in- $sbindir. [GL #1724]
- The BIND 9 build system has been changed to use a typical autoconf+automake+libtool stack. This should not make any difference for people building BIND 9 from release tarballs, but when building BIND 9 from the Git repository, - autoreconf -fineeds to be run first. Extra attention is also needed when using non-standard- configureoptions. [GL #4]
Bug Fixes
- Log files using - timestamp-style suffixes were not always correctly removed when the number of files exceeded the limit set by- versions. This has been fixed. [GL #828]
License
BIND 9 is open source software licensed under the terms of the Mozilla Public
License, version 2.0 (see the COPYING file for the full text).
Those wishing to discuss license compliance may contact ISC at https://www.isc.org/contact/.
End of Life
BIND 9.18 (Extended Support Version) will be supported until at least December, 2025. See https://kb.isc.org/docs/aa-00896 for details of ISC’s software support policy.
Thank You
Thank you to everyone who assisted us in making this release possible.