Technitium DNS Server https://technitium.com/dns/

Shreyas Zare 6a7e467697 assembly version updated for release 3 years ago
.github 4dde4cce9b Create FUNDING.yml 3 years ago
Apps fe3b910abf assembly version updated for app release 3 years ago
DnsApplicationCommon d432d847e0 added API documentation. 3 years ago
DnsServerApp 6a7e467697 assembly version updated for release 3 years ago
DnsServerCore 6a7e467697 assembly version updated for release 3 years ago
DnsServerSystemTrayApp 0aec2ea64d assembly version updated for release. 3 years ago
DnsServerWindowsService 6a7e467697 assembly version updated for release 3 years ago
DnsServerWindowsSetup ee1402bca5 inno: updated dotnet to v5.0.6 3 years ago
.gitattributes 2d2826abe0 gitattributes updated 5 years ago
.gitignore bc0ab5feb9 updated git ignore 5 years ago
APIDOCS.md faff9d34e9 updated apidocs. 3 years ago
CHANGELOG.md 4a92d93e6a updated changelog 3 years ago
DnsServer.sln f8a449edda updated solution 3 years ago
LICENSE ffa38b3c08 Create LICENSE 7 years ago
README.md 5e6b66fde6 readme: added new blog post entry. 3 years ago

README.md

Technitium DNS Server
Technitium DNS Server


Get a personal local DNS Server for privacy & security.
Block Ads at DNS level!

Technitium DNS Server

Technitium DNS Server is an open source tool that can be used for self hosting a local DNS server for privacy & security or, used for experimentation/testing by software developers on their computer. It works out-of-the-box with no or minimal configuration and provides a user friendly web console accessible using any web browser.

Nobody really bothers about domain name resolution since it works automatically behind the scenes and is complex to understand. Most computer software use the operating system's DNS resolver that usually query the configured ISP's DNS server using UDP protocol. This way works well for most people but, your ISP can see and control what website you can visit even when the website employ HTTPS security. Not only that, some ISPs can redirect, block or inject content into websites you visit even when you use a different DNS provider like Google DNS or Cloudflare DNS. Having Technitium DNS Server configured to use DNS-over-TLS or DNS-over-HTTPS forwarders, these privacy & security issues can be mitigated very effectively.

Developers regularly use the hosts file for configuring an IP address for a domain under testing. However, using the hosts file is cumbersome at times and can only be used to resolve domain name to an IP address. With a fully configurable DNS server running on your local machine, you can configure not just simple A records (for IP address) but, also configure other types of records like CNAME or MX etc. This allow you to have more control and power when you want to do testing that simulates the exact configuration that you have running on production.

Applications of using a locally hosted DNS server is limited only by the user's imagination!

Features

  • Works on Windows, Linux, macOS and Raspberry Pi.
  • Installs in just a minute and works out-of-the-box with zero configuration.
  • Block Ads using one or more block list URLs.
  • Run DNS-over-TLS and DNS-over-HTTPS DNS service on your network.
  • Use public DNS resolvers like Cloudflare, Google & Quad9 with DNS-over-TLS and DNS-over-HTTPS protocols as forwarders.
  • Advance caching with features like serve stale, prefetching and auto prefetching.
  • Supports working as an authoritative as well as a recursive DNS server.
  • CNAME cloaking feature to block domain names that resolve to CNAME which are blocked.
  • QNAME minimization support in recursive resolver draft-ietf-dnsop-rfc7816bis-04.
  • QNAME randomization support for UDP transport protocol draft-vixie-dnsext-dns0x20-00.
  • ANAME propriety record support to allow using CNAME like feature at zone root.
  • APP propriety record support that allows custom DNS Apps to directly handle DNS requests and return a custom DNS response based on any business logic.
  • Support for features like Split Horizon and Geolocation based responses using DNS Apps feature.
  • Primary, Secondary, Stub, and Conditional Forwarder zone support.
  • Host domain names on your own DNS server.
  • Wildcard sub domain support.
  • Enable/disable zones and records to allow testing with ease.
  • Built-in DNS Client with option to import responses to local zone.
  • Supports out-of-order DNS request processing for DNS-over-TCP and DNS-over-TLS protocols.
  • Built-in DHCP Server that can work for multiple networks.
  • IPv6 support in DNS server core.
  • HTTP & SOCKS5 proxy support which can be configured to route DNS over Tor Network or use Cloudflare's hidden DNS resolver.
  • Web console portal for easy configuration using any web browser.
  • Built in HTTP API to allow 3rd party apps to control and configure the DNS server.
  • Built-in system logging and query logging.
  • Open source cross-platform .NET 5 implementation hosted on GitHub.

Planned Features

  • Query logging support for databases feature as a DNS App.
  • Query rate limiting per IP address option.
  • Multi-user role based access.
  • API key to provide long term access token.
  • Clustering support to manage two or more DNS servers.
  • TSIG support.
  • Dynamic DNS updates.
  • EDNS support.
  • DNSSEC support.

Installation

API Documentation

The DNS server HTTP API allows any 3rd party app or script to configure the DNS server. The HTTP API is used by the web console and thus all the actions that the web console does can be performed via the API. Read the HTTP API documentation for complete details.

Help Topics

Read the latest online help topics which contains the DNS Server user manual and covers frequently asked questions.

Support

For support, send an email to support@technitium.com. For any issues, feedback, or feature request, create an issue on GitHub.

Join /r/technitium on Reddit.

Donate

Make contribution to Technitium by becoming a Patron and help making new software, updates, and features possible.

Become a Patron now!

Blog Posts