DNS域名解析服务

DNS域名解析服务

 
BIND域名服务基础
在之前的Windows服务课程中,我们已经学习过DNS服务器的初级应用。本节主要对DNS系统的作用及类型做一个简单回顾,并学习Linux系统中BIND域名服务基础知识。
 
1.1 DNS系统的作用及类型
       整个Internet大家庭中连接了数以亿计的服务器,个人主机,其中大部分的网站,邮件等服务器都使用了域名形式的地址,例如www.google.com、mail.163.com等。很显然这种地址形式要比使用64.233.189.147、202.108.33.74的IP地址形式更加直观,而且更容易被用户记住。
       DNS系统在网络中的作用就是维护着一个地址数据库,其中记录了各种主机域名与IP地址的对应关系,以便为客户程序提供正向或反向的地址查询服务,即正向解析与反向解析。
➣   正向解析:根据域名查IP地址,即将指定的域名解析为相对应的IP地址。域名的正向解析是DNS服务器最基本的功能,也是最常用的功能。
➣   反向解析:根据IP地址查域名,即将指定的IP地址解析为相对应的域名。域名的反向解析不是很常用,只在一些特殊场合才会用到,如可用于反垃圾邮件的验证。
       实际上,每一台DNS服务器都只负责管理一个有限范围(一个或几个域)内的主机域名和IP地址的对应关系,这些特定的DNS域或IP地址段称为“zone”(区域)。根据地址解析的方向不同,DNS区域相应地分为正向区域(包含域名到IP地址的解析记录)和反向区域(包含IP到域名的解析记录) 。
       根据所管理的区域地址数据的来源不同,DNS系统可以分为不同的类型。在同一台DNS服务器中,相对于不同的区域来说也拥有不同的身份。常见的几种类型如下。
➣   缓存域名服务器:只提供域名解析结果的缓存功能,目的在于提高查询速度和效率,但是没有自己控制的区域地址数据。构建缓存域名服务器时,必须设置根域或指定其他DNS服务器作为解析来源。
➣   主域名服务器维护某一个特定DNS区域的地址数据库,对其中的解析记录具有自主控制权,是指定区城中唯一存在的权威服务器,官方服务器。构建主域名服务器时,需要自行建立所负责区域的地址数据文件。
➣   从域名服务器:与主域名服务器提供完全相同的DNS解析服务,通常用于DNS服务器的热备份。对客户机来说,无沦使用主域名服务器还是从域名服务器,查询的结果都是一样的。关键区别在于从域名服务器提供的解析结果并不是由自己决定的,而是来自于主域名服务器。构建从域名服务器时,需要指定主域名服务器的位置,以便服务器能自动同步区域的地址数据库。
 
以上所述主、从服务器的角色只是针对某一个特定的DNS区域来说的。例如,同一台DNS服务器,可以是”.chinaunix.net"区域的主域名服务器,同时也可以是”.cublog.cn"区域的从域名服务器。
 
1.2 BIND的安装和控制
BIND不是唯一能够提供域名服务的DNS服务程序,但它却是应用最为广泛的,BIND 可以运行在大多数Linux/UNIX主机中。其官方站点位于https://www.isc.org/。
1.安装BIND软件
在RHEL5系统中,系统光盘自带了BIND服务的安装文件,主要包括以下几个软包。
➣   bind-9.3.3-7.el5.i386.rpm
➣   bind-utils-9.3.3-7.el5.i386.rpm
➣   bind-libs-9.3.6-4.P1.el5_4.2
➣   bind-chroot-9.3.3-7.el5.i386.rpm
➣   caching-nameserver-9.3.3-7.el5.i386.rpm
各软件包的主要作用如下:
➣   bind:提供了域名服务的主要程序及相关文件。
➣   bind-utils:提供了对DNS服务器的测试工具程序,如nslookup等。
➣   bind-tibs:提供了bind,bind-utils需要使用的库函数。
➣   bind-chroot:为BIND服务提供一个伪装的根目录(将/var/named/chroot/文件夹作为BIND的根目录) 以提高安全性。
➣   caching-nameserver:提供构建缓存域名服务器的基本配置文件,这些文件在构建主、从域名服务器时也可以作为参考。
若在安装RHEL5系统的过程中已勾选“DNS名称服务器”,则上述软件基本上都已经装好了,只需额外安装caching-nameserver软件包即可。
[root@sky ~]# yum -y install bind*      <==推荐使用yum方式安装
 
2.BIND服务控制
BIND软件包安装完毕以后,会自动増加一个名为named的系统服务,通过脚本文件etc/init.d/named或service工具都可以控制DNS域名服务的运行,例如,执行以下操作可以查询named服务的运行状态。
[root@sky ~]# service named status
rndc: neither /etc/rndc.conf nor /etc/rndc.key was found
named-sdb 已停
 
1.3 BIND服务的配置文件
使用BIND软件构建域名服务时,主要涉及两种类型的配置文件:主配置文件和区域数据文件。其中,主配置文件用于设置named服务的全局选项,注册区域及访问控制等各种运行参数;区域数据文件用于存放某个DNS区域的地址解析记录(正向或反向记录)。
 
1.主配置文件
主配置文件named.conf通常位于/etc/目录下,如果安装了bind-chroot软件包,则主配置文件默认位于/var/named/chroot/etc/目录下(本章中为后者),需要用户手工建立。在named.conf文件中,主要包括全局配置,区域配置两个部分,每一条配置记录的行尾以分号";“表不结束,以"#"号或“//”开始的部分表示注释文字(大段注释可以使用”/*......*/"的格式) 。
 
1)全局配置部分
全局配置参数包括在形如"options{ };“的大括号中,例如可以设置监听的地址和端口,区域数据文件存放的目录,允许哪些客户机查询等。
options {
    listen-on port 53 { 192.168.1.10; };         <==监听地址和端口           
    directory   "/var/named";         <==区域数据文件的默认存放位置                       
    allow-query  { 192.168.1.0/24; 172.16.1.0/24; };       <==允许使用本DNS服务的网段
};
上述配置内容中,除了directory项通常会保留以外,其他的配置项都可以省略。若不指定listen-on配置项时,named默认在所有接口的UDP 53端口监听服务;不指定allow-query配置项时,默认会响应所有客户机的查询请求。
 
2)区域配置部分
区域配置参数使用“zone......{ };"的配置格式,一台DNS服务器可以为多个区域提供解析,因此在named.conf文件中也可以有很多个zone配置段。区域类型按照解析方向可分为正向区域、反向区域。
zone "sky.com" IN {             <==正向"sky.com”区域                         
    type master;                <==类型为主区域                                   
    file "sky.com.zone";        <==区域数据文件为sky.com.zone                         
    allow-transfer  { 192.168.1.20; };     <==允许下载的从服务器地址               
};
zone "1.168.192.in-addr.arpa" IN {         <==反向“192.168.1.0/24”区域           
    type master;
    file "192.168.1.arpa";            <==区域数据文件为192.168.1.arpa                       
};
在上述配置内容中有几个地方需要注意。
➣   每个zone区域都是可选的(包括根域,回环域,反向域),具体根据实际需要而定,zone配置部分的”IN“关键字也可以省略。
➣   反向区域的名称由倒序的网络地址和“.in-addr.arpa”组合而成,例如对于192.168.1.0/24网段,其反向区域名称表示为”1.168.192.in-addr.arpa"。
➣   file配置项用于指定实际的区域数据文件,文件名称由管理员自行设置。
➣   区域配置中的部分参数(如allow-transfer)也可以放在全局配置里。
       修改完主配置文件以后,可以执行named-checkconf命令对named.conf文件进行语法检查。如果文件中没有语法错误,该命令将不给出任何提示;反之,则会给出相应的提示信息,只要根据出错提示修正文件中的错误即可。带“-z”选项的named-checkconf命令还可以尝试加载主配置文件中对应的区域数据库文件,并检查该文件是否存在问题。例如,当出现”... file not found“的错误时,表示找不到对应的文件。
[root@sky ~]# named-checkconf -z /var/named/chroot/etc/named.conf
none:0: open: /var/named/chroot/etc/named.conf: file not found
 
2.区域数据配置文件
       区域数据配置文件通常位于/var/named/目录下。如果安装了bind-chroot软件包,到默认位于/var/named/chroot/var/named/目录下(本章中为后者),需要手工建立。每个区域数据文件对应一个DNS解析区域,文件名及内容由该域的管理员自行设置。
       根域 ”.“ 的区域数据文件比较特殊。Internet中所有的DNS服务器都使用同一份根区域数据文件,其中列出了所有根服务器的域名和IP地址。根区域数据文件可以从国际互联网络信息中心(Intec)的官方网站地址http://www.internic.net下载,文件名为 named.root 或者 named.ca。
在区域数据文件中,主要包括TTL配置项,SOA(Start Of Authortty,授权信息开始)记录,地址解析记录。文件中的注释信息以分号”;”开始。
 
1)TTL配置及SOA记录部分
第一行的TTL配置用于设置默认生存周期,即缓存解析结果的有效时间、SOA记录部分用于设置区域名称、管理邮箱,以及为从域名服务指定更新参数。
$TTL    86400            <==有效解析记录的生存周期                          
@  IN  SOA  sky.com.  admin.sky.com.  (       <==SOA标记、域名、管理邮箱
   2011030501               <==更新序列号,可以是10位以内的整数                   
   3H            <==刷新时间,重新下载地址数据的间隔     
   15M            <==重试延时,下载失败后的重试间隔                         
   1W            <==失效时间,超过该时间仍无法下载则放弃                         
   1D            <==无效解析记录的生存周期                         
)
 
上述配置内容中时间单位默认为秒,也可以使用以下单位:M(分)、H (时)、W(周)、D(天)。文件中的”@“符号表示当前的DNS区域名,相当于”sky.com.",”admin.sky.com."表示域管理员的电子邮箱地址(由于"@"符号已有其他含义,因此将邮件地址中的“@"用"."代替)。SOA记录中的更新序列号用来同步主,从服务器的区域数据,当从服务器判断区域更新时,若发现主服务器中的序列号与本地区域数据中的序列号相同,则不会进行下载。
 
2)地址解析记录部分
地址解析记录用来设置DNS区域内的域名,IP地址映射关系,包括正向解析记录和反向解析记录。反向解析记录只能用在反向区域数据文件中。
@       IN      NS         ns1.sky.com.
        IN      MX  10     mail.sky.com.
ns1     IN      A          58.119.74.203
www     IN      A          192.168.1.10
mail    IN      A          192.168.1.4
ftp     IN      CNAME      www
 
上述配置内容中,用到以下四种常见的地址解析记录。
➣   NS域名服务器(Name Server)记录:记录当前区域的DNS服务器的主机地址。
➣   MX邮件交换(Mail Exchange)记录:记录当前区域的邮件服务器的主机地址,数字10表示(当有多个MX记录时)选择邮件服务器的优先级,数字越大优先级越低。
➣   A地址(Address):记录正向解析条目。例如“www IN A 192.168.1.10”表示域名www.sky.com对应的IP地址为192.168.1.10。
➣   CNAME别名(Canonical Name):记录某一个正向解析条目的其他名称。例如“ftp IN CNAME www”表示域名ftp.sky.com是www.sky.com的别名。
其中,NS、MX记录行首的”@“符号可以省略(默认继承SOA记录行首的@信息),但是必须保留一个空格或者Tab制表位。
在反向区域数据文件中不会用到A地址记录而是使用FTR指针(Point)记录。例如对于反向区域1.168.192.in-addr.arpa,添加的反向解析记录可以是以下形式。
1       IN      PTR     www.sky.com. 
4       IN      PTR     mail.sky.com.
 
       使用PTR记录时第一列中只需要指明对应IP地址的主机地址部分即可,如”1”、“4”等。系统在查找地址记录时会自动将当前反向域的网络地址作为前缀。例如上述文件中的“4 IN PTR mail.sky.com"表示IP地址为192.168.1.4的主机的域名是mail.sky.com.。
       在区域数据配置文件中,凡是不以点号”."结尾的主机地址,系统在查找地址记录时都会自动将当前的域名作为后缀。例如,若当前的DNS域为"sky.com",则在文件中的主机地址"www"相当于“www.sky.com.",因此,当使用完整的FQDN 地址时,务必记得地址末尾的点号"."不能省略。
       修改完区域数据文件以后,可以执行named-checkconf命令对该文件进行语法检查。依次指定区域名称、数据文件名作为参数,如果文件中没有语法错误,系统将给出”OK“的提示信息。例如,若要检查DNS区域sky.com的区域数据文件sky.com.zone,可以执行以下操作. 
[root@localhost ~]# cd /var/named/chroot/var/named/
[root@localhost named]# named-checkzone sky.com sky.com.zone
zone sky.com/IN: loaded serial 2011030501
OK
 
当一台服务器需要同时承载某个DNS区域内的许多个不同的域名时(如IDC的虚拟主机服务器,提供个人主页空间的网站服务器等)可以在区域数据文件的最后一行添加泛域名解析记录,即使用"*"以匹配任意主机名。
*          IN     A          192.168.1.100
 
 
2. 使用BIND构建域名服务器
2. 1 构建缓存域名服务器
缓存域名服务器通常架设在公司的局域网内,主要目的是提高域名解析的速度,减少对互联网访问的出口流量。例如在一个小型企业的内部网络(如图所示)中可单独建立一台(或集成在网关主机中)缓存域名服务器,为各部门的员工电脑提供DNS解析服务。
参考上述网络结构,本小节案例使用的基本环境和要求如下所述。
➣   缓存域名服务器的IP地址为192.168.1.5,并能够正常访问互联网。
➣   缓存域名服务器代为处理客户端的DNS解析请求并缓存查询结果。
➣   局域网内的各PC将首选DNS服务器地址设为192.168.1.5。
下面讲解使用BIND构建此缓存域名服务器的基本步骤。
 
1. 建立主配置文件named.conf 
在安装好caching-nameserver软件包以后系统会提供相关的基础配置文件,只需稍作改动即可完成缓存域名服务器的配置。根据缓存配置named.caching一nameserver.conf文件中的内容,通过“include”语句包含了文件named.rfc1912.zones中的区域设置(如根域,回环域),默认为只面向本机提供域名查询服务。
若使用范本文件创建named.conf,应注意修改或删除默认的监听设置,查询控制,以便能够为局城网段的客户机提供服务。另外logging,view配置部分一般用不到,可以先注释以避免其干抗。
[root@localhost ~]# vi /etc/named.conf
options {
        listen-on port 53 { 192.168.1.5; };              
        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-query  { 192.168.1.0/24; };                
        recursion  yes;                                  
};
zone "." IN {          <==正向"."根区域    
type hint;             <==类型为根区域                            
file "named.ca";       <==区域数据文件为named.ca                           
};
 
上述配置内容中,dump-file、statistics-file、memstatistics-file等配置项用于指定缓存数据库文件,状态统计文件的位置。添加了“zone ”.“ IN { } ;"部分的根区域设置,尽管缓存服务器并没有自主控制的区域数据,但可以向根服务器进行迭代查询,并将最终获得的解析结果反馈给客户。
有时候为了提高解析效率,也可以不向根区域查询,而是将来自客户端的查询清求转发给国内电信运营商的DNS服务器(如北京的202.106.0.20,202.106.148.1),缓存服务器收到返回的查询结果后再传递给客户端。只要去掉“zone ”.“ IN {......} ;"设置,并在全局配置中正确设置forwarders参数即可实现该功能。
[root@localhost ~]# vi /etc/named.conf
options {
        listen-on port 53 { 192.168.1.5; };              
        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";
        forwarders { 202.106.0.20; 202.106.148.1; };
        recursion  yes;                                  
};
 
2. 确认根域的区域数据文件 named.ca 
根区域的区域数据文件默认位于文件/var/named/chroot/var/named/named.ca中,该文件记录了internet中的13台根域服务器的域名和IP地址等相关信息。
[root@sky ~]# cd /var/named/
[root@sky named]# grep -v "^;" named.ca | grep -v ^$
.           518400  IN  NS  a.root-servers.net.
.           518400  IN  NS  b.root-servers.net.
.           518400  IN  NS  c.root-servers.net.
.           518400  IN  NS  d.root-servers.net.
.           518400  IN  NS  e.root-servers.net.
.           518400  IN  NS  f.root-servers.net.
.           518400  IN  NS  g.root-servers.net.
.           518400  IN  NS  h.root-servers.net.
.           518400  IN  NS  i.root-servers.net.
.           518400  IN  NS  j.root-servers.net.
.           518400  IN  NS  k.root-servers.net.
.           518400  IN  NS  l.root-servers.net.
.           518400  IN  NS  m.root-servers.net.
a.root-servers.net. 518400  IN  A   198.41.0.4
b.root-servers.net. 518400  IN  A   192.228.79.201
c.root-servers.net. 518400  IN  A   192.33.4.12
d.root-servers.net. 518400  IN  A   199.7.91.13
e.root-servers.net. 518400  IN  A   192.203.230.10
f.root-servers.net. 518400  IN  A   192.5.5.241
g.root-servers.net. 518400  IN  A   192.112.36.4
h.root-servers.net. 518400  IN  A   128.63.2.53
i.root-servers.net. 518400  IN  A   192.36.148.17
j.root-servers.net. 518400  IN  A   192.58.128.30
k.root-servers.net. 518400  IN  A   193.0.14.129
l.root-servers.net. 518400  IN  A   199.7.83.42
m.root-servers.net. 518400  IN  A   202.12.27.33
a.root-servers.net. 518400  IN  AAAA    2001:503:ba3e::2:30
c.root-servers.net. 518400  IN  AAAA    2001:500:2::c
d.root-servers.net. 518400  IN  AAAA    2001:500:2d::d
f.root-servers.net. 518400  IN  AAAA    2001:500:2f::f
h.root-servers.net. 518400  IN  AAAA    2001:500:1::803f:235
i.root-servers.net. 518400  IN  AAAA    2001:7fe::53
j.root-servers.net. 518400  IN  AAAA    2001:503:c27::2:30
k.root-servers.net. 518400  IN  AAAA    2001:7fd::1
l.root-servers.net. 518400  IN  AAAA    2001:500:3::42
m.root-servers.net. 518400  IN  AAAA    2001:dc3::35
 
3.启动named服务
执行“service named start”命令,启动named服务,并通过netstat命令确认named 服务的端口监听状态。若服务启动失败或发现没有正常监听UDP53端口,可以根据错误提示信息(或者/var/log/messages文件中的日志记录)排除错误,然后再重启服务即可。
[root@sky ~]# service named start
启动 named:                                               [确定]
[root@sky ~]# netstat -anpt | grep named
tcp        0      0 127.0.0.1:53                0.0.0.0:*                   LISTEN      2747/named-sdb 
 
4.验证缓存域名服务器
在局城网内的客户机中,将首选DNS服务器的地址设为192.168.1.5(缓存域名服务器的地址),然后执行“nslookup www.google.com"命令对其进行解析,验证其是否能够获得该域名对应的IP地址信息。
C:\Users\starryisky>nslookup www.google.com
服务器:  192.168.1.5
Address:  192.168.1.5
 
非权威应答:
名称:    www.google.com
Addresses:  64.233.187.103
          64.233.187.105
          64.233.187.106
          64.233.187.104
          64.233.187.147
          64.233.187.99
 
2.2 构建主域名服务器
主域名服务器通常架设在Internet环境中,提供某一个域或某几个域内的主机名与IP地址的查询服务。为了分担域名查询的压力、提供区域数据的备份,有时还会另外架设一台从域名服务器,与主域名服务器同时提供服务(如图所示)。
基本网络环境和要求如下所述.:
➣   主、从域名服务器均位于Internet中,所负责的DNS区域为“sky.com”。
➣   主服务器的IP地址为192.168.1.10,主机名为ns1.sky.com。
➣   从服务器的IP地址为192.168.1.20,主机名为ns2.sky.com。
➣   在sky.com区域中,除了NS记录以外,提供的解析记录还包括以下内容。
◆   网站服务器www.sky.com,IP地址为192.168.1.100
◆   邮件服务器mail.sky.com,IP地址为192.168.1.101
◆   在线培训服务器study.sky.com,IP地址为192.168.1.102。
➣   参考上述各服务器的地址映射关系,为192.168.1.0/24网段提供反向解析。
➣   设置sky.com域的泛域名解析,对应的IP地址为192.168.1.1。
➣   客户机将首选,备用DNS服务器分别设为192.168.1.10和192.168.1.20,使用其中的任何一个服务器,都能够正常查询sky.com区域主机地址。
 
下面首先讲解使用BIND构建主域名服务器的基本步骤:
(1)确认本机的网络地址,主机映射,默认DNS服务器地址。
将主域名服务器的IP地址设为192.168.1.10,主机名设为ns1.sky.com,通过修改网络配置文件的方式进行,具体操作过程略。另外为了提高域名解析效率,建议将两个DNS服务器的地址映射直接写入到/etc/hosts文件中,并在/etc/resolv.conf文件中指定两个DNS服务器的地址。
[root@localhost ~]# vim /etc/sysconfig/network
HOSTNAME=ns1.sky.com
[root@ns1 ~]# vim /etc/hosts
192.168.1.10 ns1.sky.com
192.168.1.20 ns2.sky.com
[root@ns1 ~]# vim /etc/resolv.conf 
nameserver 192.168.1.10
nameserver 192.168.1.20
 
(2)建立主配置文件named.conf。
新创建的named.conf主配置文件,由于只需要提供sky.com域的正向解析和192.168.1.0/24网段的反向解析,因此相应地添加这两个区域即可。根区域,回环域等其他配置内容可以省略。
[root@ns2 ~]# yum -y install bind*      <==安装bind软件包
[root@ns2 ~]# service named restart     启动named服务
[root@ns1 ~]# vim /etc/named.conf
options {
listen-on port 53 { 192.168.1.10; }; <==监听端口和地址
     directory       "/var/named"; <==区域数据默认存放的位置
allow-query     { 192.168.1.0/24; }; <==允许使用本DNS服务器的网段
};
zone "sky.com" IN {
     type master; <==类型为主区域
     file "sky.com.zone"; <==区域数据文件为sky.com.zone
     allow-transfer { 192.168.1.20; }; <==允许从服务器下载正向区域数据
};
zone "1.168.192.in-addr.arpa" IN {
     type master;
     file "192.168.1.arpa"; <==区域数据文件为192.168.1.arpa
     allow-transfer { 192.168.1.20; }; <==允许从服务器下载反向区域数据
};
当不需要建立从域名服务器时,上述配置内容中的”allow-transfer......“部分可以不添加;当不需要提供反向解析时,zone "1.168.192.in-addr.arpa"部分可以去掉。
 
(3)建立正,反向区域数据文件。
根据named.conf中的zone区域设置,分别建立正向区域数据文件sky.com.zone,反向区域数据文件192.168.1.arpa。配置内容可以参考回环域的区域数据文件/var/named/named.localhost,并根据实际情况进行修改。
[root@ns1 ~]# cd /var/named/
[root@ns1 named]# vim sky.com.zone <==创建正向区域数据文件
$TTL 86400
@ SOA sky.com. admin.sky.com. (
        2015051801
        4H
        30M
        12H
        1D
)
@        IN      NS      ns1.sky.com.
         IN      NS      ns2.sky.com.
         IN      MX  10  mail.sky.com.
ns1      IN      A       192.168.1.10
ns2      IN      A       192.168.1.20
www      IN      A       192.168.1.100
mail     IN      A       192.168.1.101
study    IN      A       192.168.1.102
*        IN      A       192.168.1.1
 
[root@ns1 named]# vim 192.168.1.arpa <==创建反向区域数据文件
$TTL 86400
@ SOA sky.com. admin.sky.com. (
        2015051801
        4H
        30M
        12H
        1D
)
        IN      NS      ns1.sky.com.
        IN      NS      ns2.sky.com.
100     IN      PTR     www.sky.com.
101     IN      PTR     mail.sky.com.
102     IN      PTR     study.sky.com.
10      IN      PTR     ns1.sky.com.
20      IN      PTR     ns2.sky.com.
 
(4)启动named服务或重载配置。
执行“service named start”命令以启动named服务,如果之前named服务已经在运行,也可以重启服务或重载配置。
[root@ns1 named]# service named restart
 
(5)验证主域名服务器。
在客户端将DNS服务器指向192.168.1.10(主域名服务器的IP地址) 使用nslookup命令验证DNS查询结果。例如,以下操作使用Windows7客户机分别验证了正向解析、泛域名解析、反向解析的查询结果。
[root@ns1 ~]# iptables -A INPUT -p tcp --dport 53 -j ACCEPT <==开放DNS的53号端口
windows客户机测试:
C:\Users\Administrator>nslookup study.sky.com
服务器:  ns1.sky.com
Address:  192.168.1.10
名称:    study.sky.com
Address:  192.168.1.102
C:\Users\Administrator>nslookup xxyyzz.sky.com
服务器:  ns1.sky.com
Address:  192.168.1.10
名称:    xxyyzz.sky.com
Address:  192.168.1.1
C:\Users\Administrator>nslookup 192.168.1.101
服务器:  ns1.sky.com
Address:  192.168.1.10
名称:    mail.sky.com
Address:  192.168.1.101
 
2.3构建从域名服务器
本小节将延续2.2小节中的应用案例,在已经构建好主域名服务器192.168.1.10的基础之上,继续构建从域名服务器192.168.1.20。
 
1.确认本机的网络地址、主机映射、默认DNS服务器地址
将从域名服务器的IP地址设为192.168.1.20,主机名设为ns2.sky.com,通过修改网络配置文件的方式进行。另外,主机映射文件/etc/hosts和DNS 解析文件/etc/resolv.conf的内容与主服务器中的内容相同。
[root@localhost ~]# vim /etc/sysconfig/network
HOSTNAME=ns2.sky.com
[root@ns2 ~]# vim /etc/hosts
192.168.1.10 ns1.sky.com
192.168.1.20 ns2.sky.com
[root@ns2 ~]# vim /etc/resolv.conf 
nameserver 192.168.1.10
nameserver 192.168.1.20
 
2.建立主配置文件named.conf 
在从域名服务器中named.conf文件的内容与主服务器的内容大部分相同,只是不需要再设置”allow-transfer ·  ·  ·  ·  ·  · ”;更关键的一点是,zone部分的区域类型应设置为slave并添加"masters{ }");语句来指定主域名服务器的地址。
[root@ns2 ~]# yum -y install bind*      <==安装bind软件包
[root@ns2 ~]# service named restart     启动named服务
[root@ns2 ~]# vim /etc/named.conf 
options { 
     listen-on port 53 { 192.168.1.20; };    <==监听端口和地址
     directory       "/var/named";           <==区域数据默认存放的位置
     allow-query     { 192.168.1.0/24; };    <==允许使用本DNS服务器的网段
zone "sky.com" IN {
     type slave;        <==类型为从区域
     masters { 192.168.1.10; };     <==指定主服务器的IP地址
     file "slaves/sky.com.zone";      <==下载的区域文件保存到slaves/目录
};
zone "1.168.192.in-addr.arpa" IN {
     type slave;
masters { 192.168.1.10; };
     file "slaves/192.168.1.arpa";
};
由于从服务器的区域数据文件是从主服务器中下载而来,因此该文件保存的名称可以自行定义,不用非得与主服务器中的一致。但需要注意的是,named服务默认以名为”named“的用户身份运行,因此要确认named用户对存放目录有写入权限。
[root@ns2 ~]# ls -ld /var/named/slaves/
drwxrwx---. 2 named named 4096 Mar 10 11:55 /var/named/slaves/
 
3.启动named服务,查看区域数据文件是否下载成功
在从域名服务器中启动named服务,若配置无误,则named将会从主域名服务器中自动下载指定的区域数据文件,并保存到”slaves/”目录下。另外,通过系统日志文件/var/log/messages也可以观察到下载区域数据文件的过程。
[root@ns2 ~]# service named restart
[root@ns2 ~]# ls -lh /var/named/slaves/
-rw-r--r--. 1 named named 448 Apr 14 13:20 sky.com.zone
-rw-r--r--. 1 named named 440 Apr 14 13:17 192.168.1.arpa
 
4.验证从域名服务器
对于客户端来说,从域名服务器与主域名服务器并没有什么区别,通过主服务器能够查询到的信息,通过从服务器也同样能够查询到。验证从域名服务器时,只需要将客户端的首选DNS服务器地址设为173.16.16,6(从域名服务器的IP地址)使用nslookup命令进行正常测试即可。
[root@ns2 ~]# iptables -A INPUT -p tcp --dport 53 -j ACCEPT <==开放DNS的53号端口
windows客户机测试:
C:\Users\Administrator>nslookup study.sky.com
服务器:  ns2.sky.com
Address:  192.168.1.20
名称:    study.sky.com
Address:  192.168.1.102
C:\Users\Administrator>nslookup 192.168.1.101
服务器:  ns2.sky.com
Address:  192.168.1.20
名称:    mail.sky.com
Address:  192.168.1.101
 





posted @ 2015-05-18 14:56  Hello-Sky  阅读(694)  评论(0)    收藏  举报