У меня есть конфигурация bind9:
acl allowed {
192.168.12.0/24;
10.10.0.0/24;
};
options {
listen-on port 53 { 127.0.0.1; 192.168.12.90; 10.10.0.21; };
listen-on-v6 port 53 { ::1; };
directory "/var/named";
dump-file "/var/named/data/cache_dump.db";
statistics-file "/var/named/data/named_stats.txt";
memstatistics-file "/var/named/data/named_mem_stats.txt";
allow-notify { localnets; };
allow-query { none; };
allow-recursion { allowed; };
allow-query-cache { allowed; };
allow-transfer { 192.168.12.117; };
allow-update { none; };
blackhole { none; };
forward only;
forwarders {
192.168.12.4;
};
recursion yes;
dnssec-enable yes;
dnssec-validation yes;
bindkeys-file "/etc/named.iscdlv.key";
managed-keys-directory "/var/named/dynamic";
pid-file "/run/named/named.pid";
session-keyfile "/run/named/session.key";
};
С помощью этой конфигурации я позволил клиентам делать рекурсивные запросы, которые bind должен разрешить путем пересылки на другой DNS-сервер. Я делаю трассировку:
dig @192.168.12.90 wikipedia.org +trace
Получить: Выводит длинную трассировку, имеющую в конце:
wikipedia.org. 600 IN A 91.198.174.192
;; Received 86 bytes from 208.80.154.238#53(ns0.wikimedia.org) in 140 ms
Очевидно, что локальный DNS-сервер выполняет рекурсивные запросы, начиная с корневых серверов до ns0.wikimedia, чтобы выполнить разрешение, хотя ему было приказано только пересылать запросы(forward only;
директива).
Как можно придерживаться чистой пересылки, не разрешая DNS-серверу выполнять рекурсивные запросы?
Спасибо.
решение1
Согласно dig
руководству:
+[нет]следа- Переключить трассировку пути делегирования от корневых серверов имен для искомого имени. По умолчанию трассировка отключена. Когда трассировка включена,dig выполняет итеративные запросы для разрешения искомого имени. Он будет отслеживать ссылки с корневых серверов, показывая ответ от каждого сервера, который использовался для разрешения поиска.
Чтобы проверить, поддерживает ли ваш сервер рекурсивные запросы, просто запустите:
#dig @192.168.12.90 wikipedia.org
и посмотрите, установлен ли бит RA (Recursion Available) в заголовке ответа.
например, для DNS-сервера Google
#dig @8.8.8.8 wikipedia.org
;; flags: qr rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 0, ADDITIONAL: 1