DNS с разделенным видом BIND не работает с передачей зоны
Я устанавливаю два DNS-сервера. Один находится на брандмауэре / маршрутизаторе, другой - внутренний сервер. У меня большой опыт настройки DNS-серверов, поэтому эта проблема вызывает недоумение.
Настройка машины
Внешний адрес брандмауэра: 207.62.233.2
Внутренний адрес брандмауэра: 10.24.0.1
Вторичный внутренний адрес: 10.24.0.21
Мастер named.conf (только соответствующие части)
options {
listen-on port 53 { any; };
listen-on-v6 port 53 { any; };
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";
recursion yes;
};
view "internal" {
match-clients { 10.24.0.0/16; 127.0.0.1; };
match-recursive-only yes;
allow-recursion { clients; };
allow-transfer { 10.24.0.21; };
zone "ct.sierracollege.edu" {
type master;
file "data/db.ct.int";
};
include "/etc/named.rfc1912.zones";
zone "." IN {
type hint;
file "named.ca";
};
};
view "external" {
recursion no;
match-clients { any; };
allow-transfer { any; }; // temporarily allowed for debugging purposes
zone "ct.sierracollege.edu" {
type master;
file "data/db.ct.ext";
};
};
Что работает
Сплит DNS на брандмауэре прекрасно работает. Если я запрашиваю его с внутренней машины, я получаю внутренние ответы. Аналогичным образом, запрос его с внешнего компьютера дает мне внешние ответы. Вот внутренний запрос.
# dig @10.24.0.1 ct1.ct.sierracollege.edu
; <<>> DiG 9.5.1-P2 <<>> @10.24.0.1 ct1.ct.sierracollege.edu
; (1 server found)
;; global options: printcmd
;; Got answer:
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 51024
;; flags: qr aa rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 2, ADDITIONAL: 2
;; QUESTION SECTION:
;ct1.ct.sierracollege.edu. IN A
;; ANSWER SECTION:
ct1.ct.sierracollege.edu. 3600 IN A 10.24.0.11
;; AUTHORITY SECTION:
ct.sierracollege.edu. 3600 IN NS cs.sierracollege.edu.
ct.sierracollege.edu. 3600 IN NS fw.ct.sierracollege.edu.
;; ADDITIONAL SECTION:
cs.sierracollege.edu. 3600 IN A 10.24.0.21
fw.ct.sierracollege.edu. 3600 IN A 10.24.0.1
;; Query time: 1 msec
;; SERVER: 10.24.0.1#53(10.24.0.1)
;; WHEN: Wed Jan 6 12:57:02 2010
;; MSG SIZE rcvd: 124
Что не работает
Зональные переводы не работают правильно. Вместо переноса внутренней зоны она переносит внешнюю. Вот пример, сделанный с той же внутренней машины, что и выше:
# dig @10.24.0.1 ct.sierracollege.edu axfr
; <<>> DiG 9.5.1-P2 <<>> @10.24.0.1 ct.sierracollege.edu axfr
; (1 server found)
;; global options: printcmd
ct.sierracollege.edu. 3600 IN SOA ct.sierracollege.edu. root.ct.sierracollege.edu. 3 3600 1800 604800 3600
ct.sierracollege.edu. 3600 IN NS fw.ct.sierracollege.edu.
ct1.ct.sierracollege.edu. 3600 IN A 207.62.233.11
ct2.ct.sierracollege.edu. 3600 IN A 207.62.233.12
ct3.ct.sierracollege.edu. 3600 IN A 207.62.233.13
fw.ct.sierracollege.edu. 3600 IN A 207.62.233.2
ct.sierracollege.edu. 3600 IN SOA ct.sierracollege.edu. root.ct.sierracollege.edu. 3 3600 1800 604800 3600
;; Query time: 2 msec
;; SERVER: 10.24.0.1#53(10.24.0.1)
;; WHEN: Wed Jan 6 13:01:37 2010
;; XFR size: 7 records (messages 1, bytes 208)
Записи из файла /var/log/messages показывают, что внешний вид поражается:
Jan 6 13:01:37 fw named[17572]: client 10.24.0.21#42362: view external: transfer of 'ct.sierracollege.edu/IN': AXFR started
Jan 6 13:01:37 fw named[17572]: client 10.24.0.21#42362: view external: transfer of 'ct.sierracollege.edu/IN': AXFR ended
Следовательно, мой slaves
Каталог заполняется внешними файлами зоны, а не внутренними.
Есть идеи?
1 ответ
Вы пытались использовать ACL? Звучит смешно, я знаю. Кроме того, почему матч-рекурсивный-только включен? Разве это не заставило бы ваших клиентов получать результаты, только если они выполняют рекурсивные запросы?
acl "internal-net" {
10.24.0.0/16; 127/8;
};
view "internal" {
match-clients { "internal-net"; };
# --- I'm removing this because I'm making the daft assumption
# --- that you are trusting your clients on your internal network,
# --- so why bother restricting them? Then there's this tidbit
# --- from http://www.zytrax.com/books/dns/ch7/view.html#match-recursive-only
# --- which seems to imply that the client match will fail because
# --- the client might not be asking for recursion...
#match-recursive-only yes;
allow-recursion { "internal-net"; };
allow-transfer { "internal-net"; };
zone "ct.sierracollege.edu" {
type master;
file "data/db.ct.int";
};
include "/etc/named.rfc1912.zones";
zone "." IN {
type hint;
file "named.ca";
};
};