Skip to content
This repository was archived by the owner on Aug 18, 2025. It is now read-only.
/ GoDNS Public archive

GoDNS is a fast DNS cache server written by Go.

License

BSD-3-Clause, MIT licenses found

Licenses found

BSD-3-Clause
LICENSE
MIT
LICENSE-upstream
Notifications You must be signed in to change notification settings

ProxyFi/GoDNS

Repository files navigation

GoDNS

A simple and fast dns cache server written by go.


Similar to dnsmasq, but supports some difference features:

  • Keep hosts records in redis and the local file /etc/hosts

  • Auto-Reloads when hosts configuration is changed. (Yes, dnsmasq needs to be reloaded)

Installation & Running

  1. Install

     $ go get github.com/ProxyFi/GoDNS 
  2. Build

     $ cd $GOPATH/src/github.com/ProxyFi/GoDNS $ go build -o godns 
  3. Running

     $ sudo ./godns -c ./etc/godns.conf 
  4. Test

     $ dig www.github.com @127.0.0.1 

Use godns

$ sudo vi /etc/resolv.conf	nameserver #the ip of godns running 

Configuration

All the configuration in godns.conf is a TOML format config file.
More about Toml :https://github.com/mojombo/toml

resolv.conf

Upstream server can be configured by changing file from somewhere other than "/etc/resolv.conf"

[resolv] resolv-file = "/etc/resolv.conf" 

If multiple namerservers are set in resolv.conf, the upsteam server will try in a top to bottom order

server-list-file

Domain-specific nameservers configuration, formatting keep compatible with Dnsmasq.

server=/google.com/8.8.8.8

More cases please refererence dnsmasq-china-list

cache

Only the local memory storage backend is currently implemented. The redis backend is in the todo list

[cache] backend = "memory" expire = 600 # default expire time 10 minutes maxcount = 100000 

hosts

Force resolve domain to assigned ip, support two types hosts configuration:

  • locale hosts file
  • remote redis hosts

hosts file

can be assigned at godns.conf,default : /etc/hosts

[hosts] host-file = "/etc/hosts" 

Hosts file format is described in linux man pages. More than that , *. wildcard is supported additional.

redis hosts

This is a special requirment in our system. Must maintain a global hosts configuration, and support update the host records from other remote server. Therefore, while "redis-hosts" be enabled, will query the redis db when each dns request is reached.

The hosts record is organized with redis hash map. and the key of the map is configured.

[hosts] redis-key = "godns:hosts" 

Insert hosts records into redis

redis > hset godns:hosts www.test.com 1.1.1.1 

Compared with file-backend records, redis-backend hosts support multiple A entries.

redis > hset godns:hosts www.test.com 1.1.1.1,2.2.2.2 

Benchmark

Debug close

$ go test -bench=. testing: warning: no tests to run PASS BenchmarkDig-8 50000 57945 ns/op ok _/usr/home/keqiang/godns 3.259s 

The result : 15342 queries/per second

The test environment:

CentOS release 6.4

  • CPU:
    Intel Xeon 2.40GHZ 4 cores

  • MEM:
    46G

Web console

Joke: A web console for godns

https://github.com/kenshinx/joke

screenshot

joke

Deployment

Deployment in productive supervisord highly recommended.

 [program:godns] command=/usr/local/bin/godns -c /etc/godns.conf autostart=true autorestart=true user=root stdout_logfile_maxbytes = 50MB stdoiut_logfile_backups = 20 stdout_logfile = /var/log/godns.log 

TODO

  • The redis cache backend
  • Update ttl

LICENSE

godns is under the MIT license. See the LICENSE file for details.

About

GoDNS is a fast DNS cache server written by Go.

Topics

Resources

License

BSD-3-Clause, MIT licenses found

Licenses found

BSD-3-Clause
LICENSE
MIT
LICENSE-upstream

Stars

Watchers

Forks

Packages

No packages published

Contributors 11