Chinaunix首页 | 论坛 | 博客
  • 博客访问: 162238
  • 博文数量: 126
  • 博客积分: 1073
  • 博客等级: 上尉
  • 技术积分: 1175
  • 用 户 组: 普通用户
  • 注册时间: 2010-08-12 00:32
文章分类

全部博文(126)

文章存档

2018年(56)

2013年(1)

2012年(8)

2011年(61)

分类: LINUX

2011-01-24 21:09:08

连载

RHEL5.4配置DNS服务(1)

http://blog.chinaunix.net/space.php?uid=14762370&do=blog&id=100699

RHEL5.4配置DNS服务(3)

http://blog.chinaunix.net/space.php?uid=14762370&do=blog&id=100702

 

刚才只是配置了主DNS服务器,而且主DNS服务器也工作正常,现在我们来配置一个辅助DNS服务器。

 

配置辅助DNS服务器

DNS的东西和辅助DNS东西实际上是一模一样的,

第一步,安装软件包

[root@localhost ~]# yum -y install bind bind-chroot caching-nameserver

[root@localhost ~]#

 

第二步,复制模板文件

[root@localhost etc]#

[root@localhost etc]# cp -p named.caching-nameserver.conf named.conf

[root@localhost etc]#

 

第三步,编辑named.conf文件

[root@localhost etc]#

[root@localhost etc]# vim named.conf

[root@localhost etc]#

和主DNS配置一样就可以了。

前面的都和主DNS配置一样就可以了

 

第四步,定义zone文件。(编辑named.rfc1912.zones文件)

[root@localhost etc]#

[root@localhost etc]# vim named.rfc1912.zones

zone "example.com" IN {

        type slave;

        masters { 192.168.0.254; };

        file "slaves/example.com";

};

 

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

        type slave;

        masters { 192.168.0.254; };

        file "slaves/named.example";

};  

辅助DNS在定义zone文件的时候和主DNS有些不同

在辅助DNS里面                 type要改为slave

master { 192.168.0.254; };    而且必须指定主DNSIP address

file "slaves/example.com";   

file "slaves/named.example";

为什么要指定数据库文件在slaves目录下面呢

是因为slaves目录是拥有人和拥有组都是named用户,在启动DNS服务的时候,只有named有权限进行操作,所以我们要把数据库放在这个目录下面。

[root@localhost ~]#

[root@localhost ~]# cd /var/named/chroot/var/named/

[root@localhost named]#

[root@localhost named]# ll  |  grep  slaves

drwxrwx--- 2  named  named    4096    Jul   27  2004 slaves

[root@localhost named]# cd slaves/

[root@localhost slaves]# ls

[root@localhost slaves]#

可以看到,slaves目录的拥有人和拥有组是named,并且现在的slaves目录下面是什么东西都没有的。

现在我们重启一下DNS服务,

[root@localhost ~]#

[root@localhost ~]# service named restart

Stopping named:                                           [  OK  ]

Starting named:                                             [  OK  ]

[root@localhost ~]#

可以看到,服务启动成功了。

在启动服务的同时,我们来查看一下日志信息,看看日志里面有什么提示。

[root@localhost ~]#

[root@localhost ~]# tail /var/log/messages

Feb 21 18:23:00 localhost named[7394]: zone example.com/IN/localhost_resolver: Transfer started.

Feb 21 18:23:00 localhost named[7394]: transfer of 'example.com/IN' from 192.168.0.254#53: connected using 192.168.0.10#55165

Feb 21 18:23:00 localhost named[7394]: zone example.com/IN/localhost_resolver: transferred serial 2010022101

Feb 21 18:23:00 localhost named[7394]: transfer of 'example.com/IN' from 192.168.0.254#53: end of transfer

[root@localhost ~]#

在日志里面可以看到,主DNS与辅助DNS正在同步序列号,同步成功,这个日志里面的信息非常的详细。

接下来,我们在到slaves目录下面去看看,

[root@localhost named]# cd slaves/

[root@localhost slaves]# ll

total 8

-rw-r--r-- 1 named named 461 Feb 21 18:23 example.com

-rw-r--r-- 1 named named 531 Feb 21 18:23 named.example

[root@localhost slaves]#

刚才slaves目录下面的是什么东西都没有的,现在就多了两个文件,example.comnamed.example这个两个文件。这个就是我们刚才在定义zone文件的时候在slaves目录下面定义的,文件名是随意写的,这个没有关系,但是里面东西是和主DNS一样的。

我们打开这个两个文件来看一下

[root@localhost slaves]#

[root@localhost slaves]# vim example.com

$ORIGIN .

$TTL 86400      ; 1 day

example.com      IN SOA  server1.example.com. root.exmaple.com. (

                                2010022101 ; serial

                                10800          ; refresh (3 hours)

                                900              ; retry (15 minutes)

                                604800        ; expire (1 week)

                                86400          ; minimum (1 day)

                                )

                      NS      server1.example.com.

$ORIGIN example.com.

server1                  A       192.168.0.254

station10               A       192.168.0.10

station20               A       192.168.0.20

station30               A       192.168.0.30

station40               A       192.168.0.40

station50               A       192.168.0.50

 

[root@localhost slaves]#

[root@localhost slaves]# vim example.com

$ORIGIN .

$TTL 86400      ; 1 day

0.168.192.in-addr.arpa  IN SOA  server1.example.com. root.example.com. (

                             2010022101 ; serial

                             28800           ; refresh (8 hours)

                             14400           ; retry (4 hours)

                             3600000       ; expire (5 weeks 6 days 16 hours)

                             86400           ; minimum (1 day)

                                )

                        NS      server1.example.com.

$ORIGIN 0.168.192.in-addr.arpa.

10                       PTR     station10.example.com.

20                       PTR     station20.example.com.

254                     PTR     server1.example.com.

30                       PTR     station30.example.com.

40                       PTR     station40.example.com.

50                       PTR     station50.example.com.

这两个文件里面的内容和我们的主DNS的内容都是一样的。而且还帮我们整理的非常的漂亮。这些都是系统自动生成的。

现在我们来测试一下主DNS和辅助DNS可不可以正常的工作呢,

[root@localhost ~]#

[root@localhost ~]# vim /etc/resolv.conf

search example.com

nameserver 192.168.0.254

nameserver 192.168.0.10

现在我们将主DNS和辅助DNS都设置一下。

然后在使用nslookup工具来测试

[root@localhost ~]# nslookup

> 192.168.0.254

Server:         192.168.0.254

Address:        192.168.0.254#53

 

254.0.168.192.in-addr.arpa      name = server1.example.com.

> station10.example.com.

Server:         192.168.0.254

Address:        192.168.0.254#53

 

Name:   station10.example.com

Address: 192.168.0.10

现在解析没有问题,还是有192.168.0.254这台主DNS来解析的。

接下来,我们将192.168.0.254这台主DNSdown,看下192.168.0.10这台辅助DNS能否正常工作。

[root@localhost ~]# service named stop

Stopping named:                                            [  OK  ]

[root@localhost ~]#

192.168.0.254这台主DNS已经被我们停止了。

在用nslookup来测试一下,

[root@localhost ~]# nslookup

> 192.168.0.254

Server:          192.168.0.10

Address:        192.168.0.10#53

 

254.0.168.192.in-addr.arpa      name = server1.example.com.

> station20.example.com.

Server:          192.168.0.10

Address:        192.168.0.10#53

 

Name:   station20.example.com

Address:   192.168.0.20

现在解析照样成功了,现在并不是通过192.168.0.254这台主DNS来解析出来的,而是通过我们的192.168.0.10这台辅助DNS来解析出来的。当我们网络中的主DNSdown掉的时候,我们的辅助DNS照样能够正常的工作。

我们还可以实现负载均衡,可以在网络中的一半客户端的主DNS指向192.168.0.254,辅助DNS指向192.168.0.10。将网络中的另一半客户端的主DNS指向192.168.0.10,辅助DNS指向192.168.0.254。这样两台服务器都可以正常的工作,正常的为客户端解析,当其中的一台DNSdown掉后,另一台DNS也会继续的工作,这样就实现了简单的负载均衡。

到目前为止,我们的主DNS Server 和我们的辅助DNS Server都已经设置成功了,并且都可以正常的工作了。

接下来,我们在做一个试验,我们在主DNS添加一笔记录,看下辅助DNS能否学习到这笔记录,不能够在辅助DNS上面添加记录,这样没有意义,我们的主DNS一样是学习不到这笔记录的。

下面我们开始,

www             IN   A            192.168.0.254

~ 

我们已经在主DNS里面添加了一笔记录,在主DNS里面做了新的操作以后,一定要将主DNS的序列号加一。否则辅助DNS是不会来同步我们的主DNS的。

                                  2010022102      ; serial (d. adams)

我们已经将主DNS的序列号加一了,但是默认情况下,主DNS与辅助DNS的同步时间是3H,这样我们很难看到效果,我们将它改为2M

                                  2M                    ; refresh

然后在将重试时间改为2M

                                  2M                   ; retry

这样就代表每隔两分钟主DNS和辅助DNS进行同步,如果同步不成功,在隔两分钟同步一次。接下来我们将反向解析里面的也来修改一下。

                                      2010022102 ; Serial

                                      120               ; Refresh

                                      120               ; Retry

254              IN  PTR             

这样,反向解析里面也已经修改完成了。现在将DNS服务重启下,

[root@localhost ~]#

[root@localhost ~]# service named restart

Stopping named:                                            [  OK  ]

Starting named:                                              [  OK  ]

[root@localhost ~]#

重启成功,等几分钟之后在来看下效果。

现在我们到辅助DNS的正向解析数据库文件里面看一下,

[root@localhost slaves]# cat example.com

$ORIGIN .

$TTL 86400      ; 1 day

example.com         IN SOA  server1.example.com. root.exmaple.com. (

                                2010022102 ; serial

                                120               ; refresh (2 minutes)

                                120               ; retry (2 minutes)

                                604800         ; expire (1 week)

                                86400           ; minimum (1 day)

                                )

                      NS      server1.example.com.

$ORIGIN example.com.

server1                  A       192.168.0.254

station10               A       192.168.0.10

station20               A       192.168.0.20

station30               A       192.168.0.30

station40               A       192.168.0.40

station50               A       192.168.0.50

www                     A       192.168.0.254

[root@localhost slaves]#

OK,可以看到,我们刚才在主DNS里面添加的一条新的记录现在已经被辅助DNS同步过去了,而且辅助DNS的序列号和刷新时间,重试时间都同步了。

下来我们在到辅助DNS的反向解析数据库文件里面看一下,

[root@localhost slaves]# cat named.example

$ORIGIN .

$TTL 86400      ; 1 day

0.168.192.in-addr.arpa  IN SOA  server1.example.com. root.example.com. (

                                2010022102 ; serial

                                120               ; refresh (8 hours)

                                120               ; retry (4 hours)

                                3600000       ; expire (5 weeks 6 days 16 hours)

                                86400           ; minimum (1 day)

                                )

                           NS   server1.example.com.

$ORIGIN 0.168.192.in-addr.arpa.

10                        PTR   station10.example.com.

20                        PTR   station20.example.com.

254                      PTR   server1.example.com.

30                        PTR   station30.example.com.

40                        PTR   station40.example.com.

50                        PTR   station50.example.com.

254                      PTR  

[root@localhost slaves]#

OK,也可以看到,辅助DNS也已经同步成功了。

 

下面在来介绍DNS其他资源记录

1.      CNAME  别名解析记录

现在我们在数据库文件里面配置CNAME记录

web             IN CNAME        

~ 

别名解析记录就是将 这个域名添加一个别名,通过这个别名我们也可以访问。但是前提是 这个域名在DNS要解析的到。

现在我们来测试一下,CNAME记录有没有生效。

先将DNS服务重启一下

[root@localhost ~]#

[root@localhost ~]# service named restart

Stopping named:                                            [  OK  ]

Starting named:                                              [  OK  ]

[root@localhost ~]#

重启成功,同样的使用nslookup工具来解析一下。

[root@localhost ~]# nslookup

>

Server:           192.168.0.254

Address:        192.168.0.254#53

 

Name:  

Address: 192.168.0.254

> web.example.com

Server:           192.168.0.254

Address:        192.168.0.254#53

 

web.example.com canonical name =

Name:  

Address: 192.168.0.254

可以看到,CNAME记录解析没有问题, 有一个别名记录是web.example.com.

 

2.      泛域名解析记录

现在我们在数据库文件里面配置泛域名解析记录,

*               IN A            192.168.0.254

~ 

泛域名解析就是匹配所有,但是这个解析最好要放在数据库文件的最后面,因为读取数据库文件的时候是从上往下开始读取的,当上面全部都不匹配的时候,才会去读取泛域名解析记录。

现在我们就来测试一下,泛域名解析有没有生效。

先将DNS服务重启一下,

[root@localhost ~]#

[root@localhost ~]# service named restart

Stopping named:                                            [  OK  ]

Starting named:                                              [  OK  ]

[root@localhost ~]#

重启成功,同样的使用nslookup工具来解析一下。

[root@localhost named]# nslookup

> dfdsfsdfsdf.example.com.

Server:           192.168.0.254

Address:        192.168.0.254#53

 

Name:   dfdsfsdfsdf.example.com

Address: 192.168.0.254

dfdsfsdfsdf.example.com.这个域名都能够被解析成功,也就是说example.com的所有域名都可以被解析到。

3.      MX记录  邮件交换记录

现在我们在数据库文件中文件邮件交换记录,

@               IN MX 10        mail.example.com.

~

当有客户端向example.com这个域发邮件,那么客户端怎么会指定将邮件发给example.com域下面的mail.example.com.,就是因为这个MX记录定义的。Mail.example.com就是example.com这个域的邮件服务器。

现在我们就来测试一下,MX记录有没有生效。

先将DNS服务重启一下,

[root@localhost ~]#

[root@localhost ~]# service named restart

Stopping named:                                            [  OK  ]

Starting named:                                              [  OK  ]

[root@localhost ~]#

重启成功,使用dig工具来查询一下。

[root@localhost ~]#

[root@localhost ~]# dig -t MX example.com.

 

; <<>> DiG 9.3.6-P1-RedHat-9.3.6-4.P1.el5 <<>> -t MX example.com.

;; global options:  printcmd

;; Got answer:

;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 23948

;; flags: qr aa rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 1, ADDITIONAL: 2

 

;; QUESTION SECTION:

;example.com.                    IN      MX

 

;; ANSWER SECTION:

example.com.              86400    IN      MX      10 mail.example.com.

 

;; AUTHORITY SECTION:

example.com.              86400    IN      NS      server1.example.com.

 

;; ADDITIONAL SECTION:

mail.example.com.        86400    IN       A       192.168.0.254

server1.example.com.   86400    IN       A       192.168.0.254

 

;; Query time: 2 msec

;; SERVER: 192.168.0.254#53(192.168.0.254)

;; WHEN: Mon Feb 22 13:02:08 2010

;; MSG SIZE  rcvd: 104

 

[root@localhost ~]#

Dig命令显示的很详细,MX也查询到了。

 

总结:

DNS中的资源记录类型有那些

(1) SOA资源记录

每个数据库文件按的开始处都包含了一个起始授权记录(Start of Authority Record,简称SOA记录。SOA定义了域的全局参数,进行整个域的管理设置。一个区域文件只允许存在唯一的SOA记录。

(2) NS资源记录

名称服务器(NS)资源记录表示该区的授权服务器,它们表示SOA资源记录中指定的该区的主和辅助服务器,也表示了任何授权区的服务器。每个区在区根处至少包含一个NS记录。

(3) A资源记录

地址(A)资源记录把FQDN映射到IP地址,因而解析器能查询FQDN对应的IP地址。

(4) PTR资源记录

相对于A资源记录,指针(PTR)记录把IP地址映射到FQDN

(5) CNAME资源记录

规范名字(CNAME)资源记录创建特定FQDN的别名。用户可以通过定义的CANME记录中的别名来访问

(6) MX资源记录

邮件交换(MX)资源记录为DNS域名指定邮件交换服务器。邮件交换服务器是为DNS域名处理或转发邮件的主机。处理邮件指把邮件投递到目的地或转交另一不同类型的邮件传送者。转发邮件指把邮件发送到最终目的服务器。

(7) 泛域名解析记录

除了在数据库文件中定义的资源记录以为,其他的所有域名都可以被DNS所解析出来。

阅读(671) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~