DNS服务器主从文件加载失败,BIND主从服务器配置以及故障排除

1      主辅DNS服务器同步原理

主辅DNS服务器数据同步的过程,首先master DNS服务器每次修改完成并重启服务后,将传送notify给所有的slave DNS服务器。slave DNS服务器将查询master服务器的SOA记录,master DNS服务器收到请求后将SOA记录发送给Slave DNS服务器,Slave DNS服务器收到后同时对比查询结果中的serial值,如果serial值不大于本机的话将结束数据同步过程;但是如果serial值大于本机的话,slave DNS将发送zone transfer请求要求(AXFR/IXFR)。Master响应zone transfer请求并传送结果,直到整个slave更新完成。

DNS服务器主从文件加载失败,BIND主从服务器配置以及故障排除_第1张图片

2      主辅DNS服务器安装配置

这里主服务器的IP为192.168.2.164,从服务器IP为192.168.2.163

安装配置我前面文章已经配置过,这里就不安装配置了,我贴出相关的配置文件。

主服务器:

named.conf:

[root@localhost etc]# more named.conf

// named.rfc1912.zones:

//

// Provided by Red Hat caching-nameserver package

//

// ISC BIND named zone configuration for zones recommended by

// RFC 1912 section 4.1 : localhost TLDs and address zones

//

// See /usr/share/doc/bind*/sample/ for example named configuration files.

//

options {

directory     "/var/named";

};

zone "." IN {

type hint;

file "named.ca";

};

zone "localdomain" IN {

type master;

file "localdomain.zone";

allow-update { none; };

};

zone "localhost" IN {

type master;

file "localhost.zone";

allow-update { none; };

};

zone "0.0.127.in-addr.arpa" IN {

type master;

file "named.local";

allow-update { none; };

};

zone "0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.ip6.arpa" IN {

type master;

file "named.ip6.local";

allow-update { none; };

};

zone "255.in-addr.arpa" IN {

type master;

file "named.broadcast";

allow-update { none; };

};

zone "0.in-addr.arpa" IN {

type master;

file "named.zero";

allow-update { none; };

};

zone "2.168.192.in-addr.arpa" IN {

type master;

file "2.168.192.zone";

allow-transfer { 192.168.2.163; };

notify yes;

also-notify{ 192.168.2.163;}

};

zone "test.com" IN {

type master;

file "test.com";

allow-transfer { 192.168.2.163;};

notify yes;

also-notify{ 192.168.2.163;};

};

test.com:

[root@localhost named]# more test.com

$TTL    86400

@ IN SOA ns.test.com.       root.test.com. (

42              ; serial (d. adams)

3H              ; refresh

15M             ; retry

1W              ; expiry

1D )            ; minimum

IN NS           ns.test.com.

IN A            192.168.2.164

ns               IN A            192.168.2.164

www            IN A            192.168.2.164

2.168.192.zone:

[root@localhost named]# more .2.168.192.zone

$TTL    86400

2 .168.192.in-addr.arpa. IN  SOA  ns.test.com. root.localhost.  (

1997022700 ; Serial

28800      ; Refresh

14400      ; Retry

3600000    ; Expire

86400 )    ; Minimum

@        IN      NS       ns.test.com.

8          IN      PTR     ns.test.com.

从服务器:

从服务器的安装很简单只需要配置named.conf文件即可,区域文件无须手动建立:

[root@localhost etc]# vi named.conf

// named.rfc1912.zones:

//

// Provided by Red Hat caching-nameserver package

//

// ISC BIND named zone configuration for zones recommended by

// RFC 1912 section 4.1 : localhost TLDs and address zones

//

// See /usr/share/doc/bind*/sample/ for example named configuration files.

//

options {

directory     "/var/named";

};

zone "." IN {

type hint;

file "named.ca";

};

zone "localdomain" IN {

type master;

file "localdomain.zone";

allow-update { none; };

};

zone "localhost" IN {

type master;

file "localhost.zone";

allow-update { none; };

};

zone "0.0.127.in-addr.arpa" IN {

type master;

file "named.local";

allow-update { none; };

};

zone "0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.ip6.arpa" IN {

type master;

file "named.ip6.local";

allow-update { none; };

};

zone "255.in-addr.arpa" IN {

type master;

file "named.broadcast";

allow-update { none; };

};

zone "0.in-addr.arpa" IN {

type master;

file "named.zero";

allow-update { none; };

};

zone "2.168.192.in-addr.arpa" IN {

type slave;

file "slaveslave.zone";

masters{192.168.2.164;};

};

zone "test.com" IN {

type slave;

file "slaves/test.salve";

masters{192.168.2.164;};

};

上述配置后,分别启动主从的DNS服务器后,从服务器会在slaves/下生成test.salve区域文件,这样主从服务器即建好了。

3     故障排除

出现错误我们一般通过日志来排查故障:tail  /var/log/message

1>  发现从服务器未同步主服务器域信息,从日志中发现如下错误:

zone test.com/IN: loading master file test.com: permission denied

这个错误一般是因为从服务器的区域文件的权限问题:

[root@localhost named] ll slaves/test.salve

-rw-r----- 1 root root 436 05-17 20:54 slaves/test.salve从这里可以看出所有者和所有组都为root,而从主服务器传送区域文件是named用户,所以我们需要修改下文件权限:[root@localhost named] chown  named.named  slaves/test.salve

[root@localhost named] service named restart

这个问题出现的原因是由于我们创建这个文件的时候,没有考虑文件权限,导致出现这个问题。直接复制/var/named/named.local这个文件后再修改的,建议复制过程中使用-p参数。这样就避免了cp后再修改权限的步骤。

2>主DNS服务器修改记录或添加区域辅助DNS同步不过去,或者需要很长时间。

这样如果在现实生活中,会造成各地访问的结果不同。所以有必要研究一下主DNS服务器上修改完成后如何快速的同步给其它辅助的DNS。

为了查清故障的原因,这个时候我分别在各个DNS服务器上开启两个终端,在第一个终端输入命令tail -f /var/log/messages动态监控日志;另一个终端中重启DNS服务。发现没有产生任何日志。这个时候,思考了一下主辅DNS的工作原理,每次主DNS修改完成后重启服务会传送notify值,但是这里却没有传送。再次回到配置文件中检查相关字段发现没有定义。这个字段可以在named.conf中options字段中声明。也可以在单个区域文件中声明。

notify yes;

also-notify{ 192.168.2.163;}

3>  主服务器更新区域文件后从服务器并能更新,但依旧无法解析

主服务器上更新区域后,但是从服务器却没有更新,但是删除从服务器上区域文件后,重新启动服务器才行,说明丛服务器是可以更新区域文件过来的,但是为什么却无法解析呢?查看日志:

client 192.168.2.164#53319: received notify for zone '2.168.192.in-addr.arpa'

May 15 18:30:37 localhost named[15926]: zone 2.168.192.in-addr.arpa/IN: notify from 192.168.2.164#53319: zone is up to date

May 15 18:30:38 localhost named[15926]: client 192.168.2.164#53319: received notify for zone 'test.com'

May 15 18:30:38 localhost named[15926]: zone test.com/IN: notify from 192.168.2.164#53319: zone is up to date

从日志可以看出,更新是可以的,但是每次更新却提示说zone是最新的,但是我明明是修改过区域文件的啊,所以这里需要了解下更新传输的过程,Slave DNS服务器是在对比查询结果中的serial值,如果serial值不大于本机的话将结束数据同步过程,

Serial﹕其格式通常會是“年月日+修改次序”     所以在更新区域文件请同时修改Serial,我们修改后,再查日志:

May 15 18:46:04 localhost named[4820]: client 192.168.2.163#47796: transfer of 'test.com/IN': AXFR-style IXFR started

May 15 18:46:04 localhost named[4820]: client 192.168.2.163#47796: transfer of 'test.com/IN': AXFR-style IXFR ended

在解决问题的过程中有的朋友说将SOA中的Refresh值修改小一点,没错!但是这个值什么时候生效呢?当我们主DNS服务器上修改完成后重启服务,会主动传送notify值,如果辅助DNS服务器没有收到才参考Refresh,Refresh 不成功,则参考Retry ,Retry 一直不成功, 则参考 Expire,如果Expire也不成功,则选择放弃zone transfer的过程。

你可能感兴趣的:(DNS服务器主从文件加载失败)