Find a file
Image Miek Gieben b1c0a306b0
All checks were successful
/ test (push) Successful in 3m21s
custom rr and custom pseudo rrs in readme
Signed-off-by: Miek Gieben <miek@miek.nl>
2025-12-24 16:36:02 +01:00
.forgejo/workflows Remove release.yaml entirely 2025-12-22 08:40:04 +01:00
cmd varius fixes, mostly documentation 2025-12-23 07:44:05 +01:00
deleg Release 0.6.10 2025-12-21 11:34:10 +01:00
dnsconf Fix tests 2025-09-06 18:04:45 +02:00
dnshttp dnshttp: docs 2025-12-22 18:01:52 +01:00
dnstest Add dnstest.NewMsg for making tests slightly shorter 2025-12-20 11:48:22 +01:00
dnsutil (chore): run modernize 2025-12-21 08:35:09 +01:00
internal Perf on per-arch basis 2025-12-21 08:51:58 +01:00
pool Revert "Use *strings.Builder for the builderPool" 2025-12-14 16:12:03 +01:00
rdata varius fixes, mostly documentation 2025-12-23 07:44:05 +01:00
svcb varius fixes, mostly documentation 2025-12-23 07:44:05 +01:00
testdata zonemd: sign root zone 2025-11-04 17:38:28 +01:00
.changelog.go.tmpl typo in changelog 2025-10-03 18:35:01 +02:00
bench_test.go Fix broken things after moving UnpackName to unpack.Name 2025-08-30 14:11:28 +02:00
CHANGELOG.md changelog 2025-12-22 15:57:51 +01:00
ci_test.go delete correct binaries 2025-09-16 17:18:56 +02:00
client.go Run golint-ci 2025-12-14 08:05:05 +01:00
client_test.go docs 2025-12-06 11:01:56 +01:00
clone_generate.go Work-in-progress commit 2025-12-12 14:01:14 +01:00
compare_generate.go Work-in-progress commit 2025-12-12 14:01:14 +01:00
CONTRIBUTORS First code dump 2025-08-06 08:11:49 +02:00
COPYRIGHT Fix copyright 2025-09-04 13:49:40 +02:00
dane.go Un-export CertificateToDANE 2025-08-16 12:43:33 +02:00
dns.go Merge pull request 'miek/wo-24-dec-25/456-changes' (#547) from miek/wo-24-dec-25/456-changes into main 2025-12-24 09:22:52 +01:00
dnssec.go Run golint-ci 2025-12-14 08:05:05 +01:00
dnssec_keygen.go lint 2025-12-15 15:35:22 +01:00
dnssec_keyscan.go golanglint-ci: run it again 2025-12-14 13:36:37 +01:00
dnssec_privkey.go golanglint-ci: run it again 2025-12-14 13:36:37 +01:00
dnssec_signer.go dns: only use one buffer for DNSSEC signatures gen/verify 2025-10-29 10:20:41 +01:00
dnssec_test.go Make it compile and fix tests 2025-12-12 14:33:07 +01:00
dnstest_generate.go Docs and clean up of comments 2025-10-06 16:13:59 +02:00
dnsutil_generate.go more 2025-12-13 19:52:08 +01:00
doc.go Allow external EDNS0 options via the Packer interface 2025-12-24 09:12:48 +01:00
dso_types.go dns: explain how to get tls ConnectionState from Conn() 2025-11-11 07:19:09 +01:00
dsolen_generate.go dso: finish remaining types 2025-11-10 06:57:44 +01:00
dsorr_generate.go Generate compare functions 2025-08-23 09:42:16 +02:00
edns_types.go Allow external EDNS0 options via the Packer interface 2025-12-24 09:12:48 +01:00
ednsrr_generate.go Test external RRs 2025-10-15 14:15:07 +02:00
errors.go typos in comments 2025-12-06 11:32:43 +01:00
generate.go builderpool 2025-12-21 09:40:59 +01:00
go.mod acl: drop infoblox and use phemmer/go-iptrie 2025-12-16 18:47:27 +01:00
go.sum acl: drop infoblox and use phemmer/go-iptrie 2025-12-16 18:47:27 +01:00
headerpack.go dns: use pointer to header 2025-12-20 15:10:54 +01:00
len_generate.go Introduce RDATA next to RR 2025-12-12 18:06:28 +01:00
LICENSE add status to the readme 2025-08-18 07:28:14 +02:00
listen_no_socket_options.go Reapply "udp: use static buffers" 2025-12-15 06:59:20 +01:00
listen_socket_options.go Reapply "udp: use static buffers" 2025-12-15 06:59:20 +01:00
Makefile.release Release 0.6.9 2025-12-21 10:57:56 +01:00
msg.go dns: more effecient packing 2025-12-20 20:12:59 +01:00
msg_generate.go Work-in-progress commit 2025-12-12 14:01:14 +01:00
msg_test.go fuzz: add dnszone.Stop 2025-12-19 18:39:48 +01:00
nsecpack.go revert some 2025-12-13 10:52:14 +01:00
opt.go Preliminary DELEG support bits 2025-08-29 20:51:46 +02:00
optpack.go return error 2025-09-07 09:52:17 +02:00
pack_generate.go Unknown types can be packed/unpacked 2025-12-03 12:52:46 +01:00
parse_generate.go More docs 2025-10-15 15:42:23 +02:00
parse_test.go dont panic in the fuzz on wrong input 2025-12-19 19:00:23 +01:00
rdata_generate.go Fix comments 2025-12-13 11:20:40 +01:00
README-dev.md update README 2025-12-16 07:33:07 +01:00
README-diff-with-v1.md varius fixes, mostly documentation 2025-12-23 07:44:05 +01:00
README.md custom rr and custom pseudo rrs in readme 2025-12-24 16:36:02 +01:00
response.go dns: explain how to get tls ConnectionState from Conn() 2025-11-11 07:19:09 +01:00
reverse.go Some lint issues 2025-10-15 09:21:04 +02:00
router Add zerr.go 2025-09-14 08:26:44 +02:00
rr_generate.go Test external RRs 2025-10-15 14:15:07 +02:00
rr_test.go Allow external EDNS0 options via the Packer interface 2025-12-24 09:12:48 +01:00
scan.go dns: ZoneParser.IncludeFS public 2025-12-22 15:01:46 +01:00
scan_ednsrr.go fix panic in NSID parser 2025-12-01 14:39:20 +01:00
scan_rr.go (chore): linter: last bits 2025-12-16 15:04:14 +01:00
scan_test.go Fix tests too 2025-12-22 15:06:17 +01:00
serve_mux.go docs 2025-12-12 08:08:54 +01:00
serve_mux_test.go Skip reflect perf testing by default 2025-08-17 12:06:55 +02:00
server.go varius fixes, mostly documentation 2025-12-23 07:44:05 +01:00
server_no_recvmmsg.go Revert "Make batchsize a server attribute" 2025-12-14 16:13:21 +01:00
server_recvmmsg.go no defer here 2025-12-21 09:45:51 +01:00
server_test.go lint 2025-12-15 15:35:22 +01:00
sig0.go Small documentation updates 2025-10-08 20:49:51 +02:00
sig0_signer.go More msg_helpers.go to internal/{un,}pack 2025-09-01 20:22:45 +02:00
smimea.go Remove t from Header 2025-11-24 16:22:48 +01:00
sort.go docs 2025-12-07 19:08:53 +01:00
sort_rdata.go Fork pool.go off into own package: pool 2025-11-22 08:03:34 +01:00
sort_test.go Make it compile and fix tests 2025-12-12 14:33:07 +01:00
string.go Revert "Use *strings.Builder for the builderPool" 2025-12-14 16:12:03 +01:00
tlsa.go Remove t from Header 2025-11-24 16:22:48 +01:00
transfer.go golanglint-ci: run it again 2025-12-14 13:36:37 +01:00
transfer_test.go Pull signing out of client 2025-09-02 16:12:55 +02:00
transport.go Dial back to dial 2025-12-06 11:04:17 +01:00
tsig.go Update docs and main readme 2025-12-22 20:09:13 +01:00
tsig_signer.go converted to rdata 2025-12-13 20:31:17 +01:00
tsig_test.go Domain -> Name, and a few other things 2025-08-28 07:09:22 +02:00
types.go varius fixes, mostly documentation 2025-12-23 07:44:05 +01:00
types_test.go Add nxdomain example 2025-12-05 16:10:02 +01:00
udp.go udp: optimize for IPv4, set control flags on darwin. 2025-09-15 10:40:02 -07:00
udp_darwin.go Migrate from net.IP to netip.Addr 2025-12-10 12:15:39 -08:00
udp_no_control.go udp: optimize for IPv4, set control flags on darwin. 2025-09-15 10:40:02 -07:00
udp_session.go Split out dns.Session to avoid repeating 2025-09-14 08:17:41 +02:00
udp_unix.go udp: optimize for IPv4, set control flags on darwin. 2025-09-15 10:40:02 -07:00
version.go Release 0.6.18 2025-12-22 16:05:51 +01:00
zclone.go edns subnet, drop "Source" from fields members 2025-12-21 10:22:58 +01:00
zcompare.go avc back 2025-12-13 11:06:58 +01:00
zdnstest.go Go gen + docs 2025-09-24 13:24:39 +02:00
zdnsutil.go Release 0.6.10 2025-12-21 11:34:10 +01:00
zdsolen.go dso: finish remaining types 2025-11-10 06:57:44 +01:00
zdsorr.go dns: more dso types 2025-11-09 19:43:26 +01:00
zednspack.go fix: Fixed EDNS0 SUBNET packing so it actually emits the address prefix bytes (based on Netmask) and aligned the option length calculation with the encoded prefix length. 2025-12-22 11:09:48 +08:00
zednsrr.go Test external RRs 2025-10-15 14:15:07 +02:00
zlen.go Introduce RDATA next to RR 2025-12-12 18:06:28 +01:00
zmsg.go avc back 2025-12-13 11:06:58 +01:00
zonemd.go some more 2025-12-14 08:09:11 +01:00
zonemd_test.go Unknown types can be packed/unpacked 2025-12-03 12:52:46 +01:00
zpack.go Unknown types can be packed/unpacked 2025-12-03 12:52:46 +01:00
zparse.go add IPN RR 2025-11-27 17:03:42 +01:00
zrdata.go Fix comments 2025-12-13 11:20:40 +01:00
zrr.go add IPN RR 2025-11-27 17:03:42 +01:00

Go Report Card Go Doc status-badge

Even more alternative approach to a DNS library (version 2)

Status

Less is more.

Complete and usable DNS library. All Resource Records are supported, including the DNSSEC types. It follows a lean and mean philosophy. Server side and client side programming is supported, i.e. you can build servers and resolvers with it.

Many convenience functions are included in dns, dnstest or otherwise in dnsutils.

We try to keep the "main" branch as sane as possible and at the bleeding edge of standards, avoiding breaking changes wherever reasonable. But because this version is young, we allow ourselves some more headroom.

Example programs are included and benchmarked in cmd, cmd/atomdns which is a full blown production ready name server.

The naming of types follows the RFCs. EDNS0 types are similarly named, for instance, DHU (Ds Hash Understood). If there is a clash between an actual RR's and an EDNS0 one, the EDNS0 type will get an 'E' as prefix, e.g. EDHU. This will also be done if the RR was named later than the EDNS0 option! The same is the for DSO (DNS Stateful Operations), when clashing those types will be prefixed with a 'D'. If EDNS0 and DSO clash, EDNS0 wins. See PADDING and DPADDING as an example.

Everything from https://github.com/miekg/dns works. See README-diff-with-v1.md for the differences, if you are porting your application.

For developers please read the developer README.

Goals

  • KISS.
  • Everything is an resource record.
    • Easy way to access RR's header and resource data (rdata).
  • Small API.
    • Package dnsutil contains functions that help programmers, but are not nessecarily in scope the the dns package.
    • Package dnstest contains functions and types that help you test, similar to the httptest package.
    • Package svcb holds all details of the SVCB/HTTPS record.
    • Pacakge deleg holds details for the DELEG record.
    • Many helper/debug functions are moved into internal packages, making the top-level much, much cleaner.
  • Fast.
    • recvmmsg(2) and TCP pipeling suppport.
    • The cmd/reflect server does ~370/300K UDP/TCP respectively on the right hardware.
    • Since a46996c I can get ~370K (UDP) qps on my laptop (M2/Asahi Linux), also see 1766e44.
    • On my Dell XPS 17 (Intel) it is similar.
    • On Intel/AMD it is lower (~200K (UDP) qps) - yet to understand why.
    • See cmd/reflect and do a go build; make new.txt. Requires dnsperf to be installed.

Users

A not-so-up-to-date-list-that-may-be-actually-current:

  • atomdns - included in cmd/atomdns - a high performance DNS server, based on the principles of CoreDNS, but faster and simpler.
  • dnscrypt-proxy - a flexible DNS proxy, with support for encrypted DNS protocols such as DNSCrypt v2, DOH, Anonymized DNSCrypt and ODOH.
  • DNSControl - DNSControl is an opinionated platform for seamlessly managing your DNS configuration across any number of DNS hosts, both in the cloud or in your own infrastructure.

Send pull request if you want to be listed here.

Comments

What users say:

miekg/dns is probably my favorite Go module in the open source ecosystem. It is very complete (every DNS rtype is defined) and strict (field names match the RFCs, etc). DNSControl has used miekg/dns since the first release.

Your library is a blast and I cannot thank you enough 🙏.

Features

  • UDP/TCP queries, recvmmsg(2), TCP query-pipelining, IPv4 and IPv6.
  • Fast.
  • RFC 1035 zone file parsing ($INCLUDE, $ORIGIN, $TTL and $GENERATE - for all record types) is supported.
  • Server side programming (mimicking the net/http package), with dns.Handle and dns.HandleFunc allowing for middleware servers.
  • Client side programming.
  • DNSSEC: signing, validating and key generation for DSA, RSA, ECDSA and Ed25519.
  • EDNS0, NSID, Cookies, etc, as pseudo RRs in the (fake) pseudo section.
  • AXFR/IXFR.
  • TSIG, SIG(0).
  • DNS over TLS (DOT): encrypted connection between client and server over TCP.
  • DNS over HTTP (DOH), see the dnshttp package.
  • Improved naming by embracing sub-packages.
  • Improved RRs, by having the rdata specified in an rdata package.
  • Examples included the cmd/ directory.
  • Escapes (\DDD and \x) in domain names is not supported (anymore) - the overhead (50-100%) was too high.
  • Easy way for custom RRs and EDNS0 pseudo RRs.

Have fun!

Miek Gieben - 2026- - miek@miek.nl

See anonymous users asking for support on why these kind of requests/issues usually get closed pretty swiftly.

Building/developing

This library uses Go modules and uses semantic versioning. Getting the code and working with the library is done via:

git clone git@codeberg.org:miekg/dns  # use https if you don't have a codeberg account
cd dns
# $EDTIOR *.go

If you want to use codeberg/miekg/dns in your own project, just do a go get codeberg.org/miekg/dns@latest and import codeberg.org/miekg/dns in your Go files.

Examples

A short "how to use the API" is at the beginning of doc.go. The cmd/ directory contains a reflect example program that is used for benchmarking, and further has atomdns which is full fledged DNS server that is developed in tandem with the library.

Supported RFCs

all of them and then some

  • 103{4,5} - DNS standard
  • 1348 - NSAP record (removed the record)
  • 1982 - Serial Arithmetic
  • 1876 - LOC record
  • 1995 - IXFR
  • 1996 - DNS notify
  • 2136 - DNS Update (dynamic updates)
  • 2181 - RRset definition
  • 2537 - RSAMD5 DNS keys
  • 2065 - DNSSEC (updated in later RFCs)
  • 2671 - EDNS record
  • 2782 - SRV record
  • 2845 - TSIG record
  • 2915 - NAPTR record
  • 2929 - DNS IANA Considerations
  • 3110 - RSASHA1 DNS keys
  • 3123 - APL record
  • 3225 - DO bit (DNSSEC OK)
  • 340{1,2,3} - NAPTR record
  • 3445 - Limiting the scope of (DNS)KEY
  • 3596 - AAAA record
  • 3597 - Unknown RRs
  • 4025 - A Method for Storing IPsec Keying Material in DNS
  • 403{3,4,5} - DNSSEC
  • 4255 - SSHFP record
  • 4343 - Case insensitivity
  • 4408 - SPF record
  • 4509 - SHA256 Hash in DS
  • 4592 - Wildcards in the DNS
  • 4635 - HMAC SHA TSIG
  • 4701 - DHCID
  • 4892 - id.server
  • 5001 - NSID
  • 5155 - NSEC3 record
  • 5205 - HIP record
  • 5702 - SHA2 in the DNS
  • 5936 - AXFR
  • 5966 - TCP implementation recommendations
  • 6605 - ECDSA
  • 6672 - DNAME
  • 6725 - IANA Registry Update
  • 6742 - ILNP DNS
  • 6840 - Clarifications and Implementation Notes for DNS Security
  • 6844 - CAA record
  • 6891 - EDNS0 update
  • 6895 - DNS IANA considerations
  • 6944 - DNSSEC DNSKEY Algorithm Status
  • 6975 - Algorithm Understanding in DNSSEC
  • 7043 - EUI48/EUI64 records
  • 7314 - DNS (EDNS) EXPIRE Option
  • 7477 - CSYNC RR
  • 7828 - TCP-keepalive EDNS0 Option
  • 7553 - URI record
  • 7719 - DNS Terminology
  • 7858 - DNS over TLS: Initiation and Performance Considerations
  • 7871 - EDNS0 Client Subnet
  • 7873 - Domain Name System (DNS) Cookies
  • 8080 - EdDSA for DNSSEC
  • 8482 - Minimal Answers for ANY
  • 8484 - DOH
  • 8499 - DNS Terminology
  • 8659 - DNS Certification Authority Authorization (CAA) Resource Record
  • 8777 - DNS Reverse IP Automatic Multicast Tunneling (AMT) Discovery
  • 8914 - Extended DNS Errors
  • 8976 - Message Digest for DNS Zones (ZONEMD RR)
  • 9250 - DOQ (not implemented, waiting until Go supports QUIC)
  • 9461 - Service Binding Mapping for DNS Servers
  • 9462 - Discovery of Designated Resolvers
  • 9460 - SVCB and HTTPS Records
  • 9499 - DNS Terminology
  • 9567 - DNS Error Reporting
  • 9606 - DNS Resolver Information
  • 9660 - Zone version
  • 9859 - DSYNC RR
  • draft-ietf-compact-denial - CO bit
  • draft-ietf-deleg - DELEG RR