20 releases

0.1.19 Mar 17, 2024
0.1.18 May 7, 2023
0.1.17 Dec 15, 2021
0.1.16 Oct 16, 2021
0.1.2 Nov 9, 2018

#133 in Unix APIs

Download history 269/week @ 2024-07-25 67/week @ 2024-08-01 349/week @ 2024-08-08 313/week @ 2024-08-15 515/week @ 2024-08-22 100/week @ 2024-08-29 325/week @ 2024-09-05 65/week @ 2024-09-12 100/week @ 2024-09-19 188/week @ 2024-09-26 55/week @ 2024-10-03 66/week @ 2024-10-10 73/week @ 2024-10-17 43/week @ 2024-10-24 96/week @ 2024-10-31 629/week @ 2024-11-07

849 downloads per month
Used in 9 crates (5 directly)

ISC license

42KB
1K SLoC

A simple and secure DNS client for Rust

API documentation

This is a DNS client crate. Some people may call that a stub resolver.

It can resolve IPv4 and IPv6 addresses. But unlike std::net::ToSocketAddrs, it directly contacts upstream servers, and doesn't depend on the system resolver. Which, in the worst case, could be systemd.

Instead, your application fully controls what upstream resolvers will be used.

It can also send raw queries, and return raw responses, retrying over multiple server candidates if necessary.

DNSClient carefully checks the consistency of every single packet it receives.

It will not let clients initiate zone transfers. It may prevent funky DNS implementations from crashing or being exploited when a malicious query or response is received.

It also transparently falls back to TCP when a truncated response is received.

Finally, its API couldn't be any simpler.

DNSClient comes with a synchronous interface (sync::*) as well as anasynchronous interface (async::*).

Cargo features:

  • async: use async-std as an async backend
  • async-tokio: use tokio as an async backend

Dependencies

~2–13MB
~158K SLoC