August 19th, 2024

Migrating Mess with DNS to Use PowerDNS

Julia Evans migrated her project Mess With DNS to PowerDNS, addressing DNS issues, improving performance with SQLite, upgrading the frontend to Vue 3, and enhancing user experience in the new version.

Read original articleLink Icon
AppreciationCuriositySurprise
Migrating Mess with DNS to Use PowerDNS

Julia Evans discusses the migration of her project, Mess With DNS, to utilize PowerDNS, an open-source DNS server with an HTTP API. Initially, the project faced several issues, including improper handling of domain names, CNAME records, and a lack of support for certain DNS record types. To address these problems, Evans decided to replace her original DNS implementation with PowerDNS. The transition involved overcoming various challenges, such as intercepting DNS queries, managing API access, and ensuring clear error messages for users. She also opted to switch from a Postgres database to SQLite to improve performance and reduce memory issues. Additionally, Evans upgraded the frontend framework from Vue 2 to Vue 3 and implemented a global state management store to streamline application state handling. After completing these updates, the new version of Mess With DNS was successfully launched, resolving many of the previous issues and enhancing user experience. Evans expressed satisfaction with the improvements and welcomed feedback on any new problems encountered.

- Julia Evans migrated Mess With DNS to PowerDNS to resolve various DNS implementation issues.

- The transition involved challenges such as intercepting DNS queries and managing API access.

- Evans switched from Postgres to SQLite for better performance and reduced memory usage.

- The frontend was upgraded from Vue 2 to Vue 3, and a global state management store was implemented.

- The new version of Mess With DNS has been launched, improving user experience and addressing past problems.

AI: What people are saying
The comments on Julia Evans' article about migrating Mess With DNS to PowerDNS reflect a mix of appreciation, technical insights, and suggestions for improvement.
  • Users express gratitude for Julia's work and recommend exploring her blog for more insights.
  • There are discussions about the challenges faced with the previous Postgres setup, particularly regarding memory issues.
  • Several commenters share their positive experiences with PowerDNS and its API, highlighting its reliability.
  • Suggestions are made for improving error messaging to enhance user understanding and experience.
  • There is curiosity about the use of CoreDNS outside of Kubernetes environments.
Link Icon 15 comments
By @benreesman - 5 months
I’ve said similar before but I’m just so impressed with Julia Evans as a technologist and technology writer/blogger: from very humble beginnings the scope and sophistication and arc of growing expertise is a masterclass in how to become a legend via putting in the work: and in an age of so many bytes on how to take shortcuts this is exactly the kind of role model we need.

In this particular instance I recall the post about DNS some years ago and the callback is amply enriched.

Keep it up @jvns. You hold us all to a high standard.

By @joeig - 5 months
> Sometimes users will still get errors from PowerDNS directly, but I added some logging of all the errors that users see, so hopefully I can review them and add extra translations if there are other common errors that come up.

I noticed that you are using our Go module to access the API. It is wonderful to see our work helping others build great software, especially for education. Thank you for that.

Please note that the upstream API sometimes changes slightly between minor releases. For example, prior to v4.9, the error response for a non-existent server was "Not Found". Starting with v4.9, it changed to "Method Not Allowed".

Unfortunately, error responses aren't always part of the API specification. I'm thinking about adding the most common cases to the module anyway.

By @chriscjcj - 5 months
Thank you very much for this wonderful experimental and educational tool.

You mentioned about your previous version:

> If there was a CNAME record for a domain name, it allowed you to create other records for that domain name, even if it shouldn’t

> you could create 2 different CNAME records for the same domain name, which shouldn’t be allowed

One suggestion... If someone makes a mistake and generates an error, it would be terrific if there were a more verbose explanation so the user may better understand why what they're trying to do won't work. I'm very much a conceptual learner. If I can understand why an error is an error, it puts me on a better path toward a more comprehensive understanding.

Thanks again for all your work.

By @e12e - 5 months
> Previously Mess With DNS was using a Postgres database. This was problematic because I only gave the Postgres machine 256MB of RAM, which meant that the database got OOM killed almost every single day. I never really worked out exactly why it got OOM killed every day, but that’s how it was.

Found this a little surprising - postgres is internet old - I'm pretty sure it was around at a time when physical servers might not have 256mb of ram?

Seems this should be possible to tune down still? (I mean, maybe not. Postgres 16 isn't postgres 6, and maybe I'm just getting old..)

By @amanzi - 5 months
The section labelled "what I learned: it’s okay for an API to duplicate information" is something I come across often in Django projects. Django views send a Python dictionary of data to the template processor to display the information. Often it's easier to massage the data into a more friendly format before sending it to the template, even if it means duplicating the info sent.
By @chrisweekly - 5 months
Julia Evans is an absolute treasure. Highly recommend exploring her blog, subscribing, etc. Signal:noise ratio is phenomenal.
By @ChocolateGod - 5 months
Been using a PowerDNS cluster in production for about 5 years using a SQL backend for replication, absolutely zero issues, not a single crash, memory leak etc in that time. The only downside is the API has a single key and you can not generate more, but there are open source projects that can put the API behind a proxy with additional keys/ACL.

Given it can read BIND files, surprised BIND is still the default in many places.

By @8organicbits - 5 months
Great write up. I'm using PowerDNS for https://www.getlocalcert.net/, which also makes heavy use of PowerDNS's HTTP API. I've been really happy with it. I need to check my code, but I remember planning to use the comment field of the records to map between application IDs and records in PowerDNS zones.

You may be able to implement the logging by using a customization of the Sqlite backend, although I think PowerDNS caching may get in your way.

I'll recommend the pipe backend to anyone looking to hack on DNS stuff. It's almost like a DNS lookup via a function in any programming language you choose. It takes a while to figure out how incoming queries are translated though.

https://doc.powerdns.com/authoritative/backends/pipe.html

By @tlofreso - 5 months
I came across Bert Hubert during covid because of his incredible work on this article: https://berthub.eu/articles/posts/reverse-engineering-source...

Long before Bert was writing articles on the source code of mRNA vaccines, he helped build PowerDNS. He talks about that in a three part series starting here: https://berthub.eu/articles/posts/history-of-powerdns-1999-2...

A fascinating individual...

https://fosstodon.org/@bert_hubert

https://github.com/berthubert

https://berthub.eu/

By @websap - 5 months
I've always enjoyed Julia's articles. I know she quit her job to do tech writing full time, but is that still true?
By @remram - 5 months
Does anyone use CoreDNS? Outside of a Kubernetes cluster I mean.
By @maltris - 5 months
As an administrator running and having run this at scale, make sure to check out:

- dnsdist DNS application aware loadbalancer

- Opera Software dns-ui

By @zelcon - 5 months
I cringe every time I see someone trying to replace good, purpose-built protocols with some bespoke HTTP crap
By @LoganDark - 5 months
> I never really worked out exactly why it got OOM killed every day

Probably you ran out of memory (and configured the database incorrectly).