Linux下使用bind搭建DNS主从服务器

假设公司A在某域名商6688.cc上注册了一个域名, 现在不想使用某域名商的DNS服务器,而是自己要建立两个DNS服务器,一个是主服务器,一个是从服务器,现有两台机器: ns1.6688.cc  ,   ns2.6688.cc   我们如何配置这两台主机成为DNS服务器?


首先,这个公司A内部有如下需求:
1.公司有一个mail服务器,需要被解析   mail.6688.cc
2.公司有一个ftp服务器,需要被解析   ftp.6688.cc
3.还有自己的域名和bbs等



好了,根据如上需求我们来配置这两台服务器。


0.在两台主机上要安装好bind服务器端,否则无法继续下去。
  1. yum install bind  
1.去某域名商6688.cc后台的管理页面上,将两台DNS服务器的地址改成自己的主机名字,改为:  (这一步在学习时省略)
ns1.6688.cc
ns2.6688.cc


2.为了保证公司的网络地址可以被正常的解析到,我们配置ns1为主服务器,ns2为从服务器,假如ns1的地址为172.16.100.1,ns2的从服务器为172.16.100.2

1)登录到172.16.100.1 即主机:ns1.6688.cc,编辑它的dns主配置文件,定义工作目录,添加两个区域,一个正向解析,一个反向解析
  1. # vim /etc/named.conf   
  2. # 正向   
  3. option {  
  4. directory "/var/named";  
  5. };  
  6. zone "6688.cc" IN {                                                # 声明复制6688.cc这个域  
  7. type master;                                         # 类型:主  
  8. file "6688.cc.zone";                                  # 解析文件  
  9. };  
  10. # 反向   
  11. zone "16.172.in-addr.arpa" IN {  
  12.         type master;  
  13.         file "172.16.zone";                 
  14. };  
  15.   
  16. # 在建立反向的时候,反向输入ip(因为它是反向解析的),例如 1.100.10.172,下面会用到  
2)配置正向解析文件6688.cc
  1. cd /var/named  
  2. vim 6688.cc  
  3. $TTL 1200  
  4. @           IN           SOA            ns1.6688.cc.             admin.6688.cc.          (                # SOA字段  
  5.                                                            2011081601                                                 # 版本号    同步一次  +1  
  6.                                                            1H                                                                   # 更新时间  
  7.                                                            10MM                                                              # 更新失败,重试更新时间  
  8.                                                            7D                                                                    # 更新失败多长时间后此DNS失效时间  
  9.                                                            1D )                                                               # 解析不到请求不予回复时间  
  10.                      IN                                NS               ns1.6688.cc.  
  11.                      IN                                NS               ns2.6688.cc.  
  12.                      IN                                MX     10        mail.6688.cc.                                # 10指优先级  0-99 数字越小优先级越高  
  13. ns1.6688.cc.     IN                              A                 172.16.100.1  
  14. ns2.6688.cc.     IN                              A                 172.16.100.2  
  15. mail.6688.cc.    IN                              A                 172.16.100.1  
  16. bbs.6688.cc.     IN                              CNAME             www.6688.cc.  
  17.   
  18. # 该文件只有改了了属组才生效!!!!!!!!   
  19. chomd :named 6688.cc.zon  
  20. service named reload  

3)配置反向解析,反向解析不去要MX , A ,和CNAME字段,它一般使用PRT

  1. vim 172.16.org  
  2.   
  3. $TTL 1200  
  4. @       IN      SOA     ns1.6688.cc.      admin.6688.cc. (  
  5.                                 2011081601  
  6.                                 1H  
  7.                                 10M  
  8.                                 7D  
  9.                                 1D )  
  10.                 IN              NS      ns1.6688.cc.  
  11.                 IN              NS      ns2.6688.cc.  
  12. 1.100           IN              PTR     ns1.6688.cc.  
  13. 2.100           IN              PTR     ns2.6688.cc.  
  14. 1.100           IN              PTR     mail.6688.cc.  
  15. 3.100           IN              PTR     www.6688.cc.  
  16. 100.100         IN              PTR     ftp.6688.cc.  
  17. # 声明域的时候已经有了,172.16 所以我们只需要输入1.100既代表172.16.1.100   
  18. chomd :named 172.16.org  
  19. service named reload  

4)启动服务,使用dig命令来测试是否能够正常解析(先修改自己的DNS服务器地址,在最后补充里)

  1. service named start  
  2. dig -t A www.6688.cc  
  3. dig -t PTR 172.16.100.1  

5)配置另外一台DNS服务器为从服务器,编辑它的主配置文件,内容如下:

  1. vim /etc/named  
  2. option {  
  3. directory "/var/named/slaves";                                     
  4. };  
  5. zone "6688.cc" IN {                         
  6. type slave;                                                                  # 类型为从  
  7. masters { 172.16.100.1 };                                       # 主服务器的地址,通过它来同步解析文件  
  8. file "6688.cc.zone";  
  9. };  
  10. # 反向   
  11. zone "16.172.in-addr.arpa" IN {  
  12.         type slave;  
  13.         masters { 172.16.100.1 };  
  14.         file "172.16.zone";                 
  15. };  

6)重启服务,看解析文件是否同步:

  1. service named restart  
  2. ls /var/named/slaves  

补充:

1.在配置DNS时,其实应当先声明一个根域".",用来解析外网域名,方法如下:

编辑主配置文件,声明根域

  1. vim /etc/named  
  2. zone "." {  
  3. type hint;  
  4. file "named.ca"  
  5. };  
  6. #保存退出,利用dig命令生成根域文件   
  7. dig -t NS ca > /var/named/named.ca  

2.修改Linux主机dns服务器地址方法:

  1. vim /etc/resolv.conf  
  2. nameserver 172.16.100.1                     # 只需要留这一行,ip是你想要设的dns服务器地址  

相关推荐