Third alpha release of PowerDNS DNSdist 1.9.0

Oct 20, 2023

We are thrilled to release the third alpha release of what will become PowerDNS DNSdist 1.9.0!

Let's first address the elephant in the room: the second alpha was never released due to a last-minute issue discovered in RPM packaging after the tag was pushed, so we went to alpha3 right away.

The most exciting new feature in this third alpha is support for DNS over QUIC, which combines the confidentiality and integrity capabilities of DNS over TLS and DNS over HTTPS without the overhead of TCP connections.
Our implementation is based on Cloudflare's Quiche, which has already been battle-tested by being used on their edge network and in Android's DNS resolver. We first selected Quiche as the building block for QUIC because the API is both simple and powerful, but also because it is written in Rust. Rust is a memory-safe language and significantly reduces the risk of security issues.
One annoying drawback is that Quiche has not yet been packaged in most Linux distributions. This is not an issue if you are using our packages, because we ship the latest release of Quiche along DNSdist, but it might make building DNSdist with DNS over QUIC support a bit harder if you are doing it on your own, as you will need to first compile Quiche. We hope that distributions will adopt Quiche in the near future.

In addition to DNS over QUIC, we also added a few new features:

  • the ability to parse Extended DNS Errors present in responses and export them via protobuf
  • Denis Machard added Lua bindings to look at the selected backend from Lua rules and actions

We also fixed a few issues:

  • phonedph1 fixed a typo on the metric name for TCP client timeouts
  • contrary to what we announced, h2o support was not available anymore in our packages in the first alpha
  • incoming DoH connections were not using the proper timeout value when handled by nghttp2
  • cosmetic issues in eBPF dynamic block reporting
  • invalid subnet masks coming from a string were not properly normalized
  • DNS header might have been misaligned in some cases, causing issues on some architectures
  • some log messages were not recorded at the proper level

Please also note that, as we did for stable releases, we switched to our own fork of libh2o in order to mitigate CVE-2023-44487, also known as HTTP/2 rapid reset.

We still have a few surprises left for 1.9.0 final, but more on that later!

Please see the DNSdist website for the more complete changelog and the current documentation.

Please send us all feedback and issues you might have via the mailing list, or in case of a bug, via GitHub.

We are grateful to the PowerDNS community for the reporting of bugs, issues, feature requests, and especially to the submitters of fixes and implementations of features.

The release tarball and its signature are available on the downloads website, and packages for several distributions are available from our repository.

About the author

Remi Gacogne

Remi Gacogne

Senior Developer at PowerDNS

Categories

Related Articles

PowerDNS DNSdist 1.9.3 released

Less than an hour after the release of PowerDNS DNSdist 1.9.2 today, we received reports of DNSdist crashing in some setups....

Remi Gacogne Apr 5, 2024

PowerDNS DNSdist 1.9.2 released

We released PowerDNS DNSdist 1.9.2 today. This release fixes several issues:

Remi Gacogne Apr 5, 2024

Improving DNSdist performance with AF_XDP

This is the second in a series of three blog posts we are publishing about recent innovative developments with respect to...

Neil Cook Mar 15, 2024

PowerDNS DNSdist 1.9.1

We released PowerDNS DNSdist 1.9.1 today. This version brings no functional changes, and only bumps the version of the...

Remi Gacogne Mar 14, 2024