coredns/core/dnsserver
Miek Gieben fcd0342e42 CIDR query routing (#1159)
* core: allow all CIDR ranges in zone specifications

Allow (e.g.) a v4 reverse on a /17. If a zone is specified in such a
way a FilterFunc is set in the config. This filter is checked against
incoming queries.

For all other queries this adds a 'x != nil' check which will not impact
performace too much. Benchmark function is added as well to check for
this as wel.

Add multiple tests in tests/server_reverse_test.go.

Benchmark shows in the non-reverse case this hardly impact the speed:

~~~
classless:
pkg: github.com/coredns/coredns/core/dnsserver
BenchmarkCoreServeDNS-4   	 1000000	      1431 ns/op	      16 B/op	       1 allocs/op

pkg: github.com/coredns/coredns/core/dnsserver
BenchmarkCoreServeDNS-4   	 1000000	      1429 ns/op	      16 B/op	       1 allocs/op

master:
pkg: github.com/coredns/coredns/core/dnsserver
BenchmarkCoreServeDNS-4   	 1000000	      1412 ns/op	      16 B/op	       1 allocs/op

pkg: github.com/coredns/coredns/core/dnsserver
BenchmarkCoreServeDNS-4   	 1000000	      1429 ns/op	      16 B/op	       1 allocs/op
~~~

* README.md updates
2017-10-24 10:16:03 +01:00
..
address.go CIDR query routing (#1159) 2017-10-24 10:16:03 +01:00
address_test.go CIDR query routing (#1159) 2017-10-24 10:16:03 +01:00
config.go CIDR query routing (#1159) 2017-10-24 10:16:03 +01:00
register.go CIDR query routing (#1159) 2017-10-24 10:16:03 +01:00
server-grpc.go Remove the word middleware (#1067) 2017-09-14 09:36:06 +01:00
server-tls.go Remove the word middleware (#1067) 2017-09-14 09:36:06 +01:00
server.go CIDR query routing (#1159) 2017-10-24 10:16:03 +01:00
server_test.go CIDR query routing (#1159) 2017-10-24 10:16:03 +01:00
zdirectives.go plugin/autopath: move after cache (#1147) 2017-10-17 20:09:25 -04:00