mirror of
				https://github.com/coredns/coredns.git
				synced 2025-10-31 02:03:20 -04:00 
			
		
		
		
	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
This commit is contained in:
		| @@ -45,8 +45,9 @@ func TestNormalizeZoneReverse(t *testing.T) { | ||||
| 		{"10.0.0.0/24.:53", "dns://10.0.0.0/24.:53", false}, | ||||
|  | ||||
| 		// non %8==0 netmasks | ||||
| 		{"2003::53/67", "dns://2003::53/67.:53", false}, | ||||
| 		{"10.0.0.0/25.", "dns://10.0.0.0/25.:53", false}, | ||||
| 		{"2003::53/67", "dns://0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.3.0.0.2.ip6.arpa.:53", false}, | ||||
| 		{"10.0.0.0/25.", "dns://10.0.0.0/25.:53", false}, // has dot | ||||
| 		{"10.0.0.0/25", "dns://0.0.10.in-addr.arpa.:53", false}, | ||||
| 	} { | ||||
| 		addr, err := normalizeZone(test.input) | ||||
| 		actual := addr.String() | ||||
|   | ||||
		Reference in New Issue
	
	Block a user