DNS域名解析之bind应用

一、环境准备

    虚拟机:vmware workstation 11 

    linux系统:centos7.3,centos6.8

    bind安装:yum install bind

    DNS主服务器A:环境:centos7.3 IP:172.16.252.35 DNS主机名:dns1.ilinux.io. 

    DNS从服务器B: 环境:centos6.8 IP:10.0.0.68 DNS主机名:dns2.ilinux.io (为后续实验准备)

    虚拟域名:www.ilinux.io

    bind主配置文件修改(centos7.3,6.8皆修改):

  #注:仅列出options{}中更改的内容,其余不变
    vi /etc/named.conf
    options {
        //listen-on port 53 { 127.0.0.1; }; #默认允许所有IP监听53端口
        //listen-on-v6 port 53 { ::1; };
        // allow-query     { localhost; };  #关闭仅允许本机解析
        dnssec-enable no;              #为了方便,关闭DNS安全功能
        dnssec-validation no;
    };

1 正向解析

步骤

  第一步:编辑解析数据库文件   

   

vi /var/named/ilinux.io.zone 
 
    $TTL 600
    ilinux.io.     IN      SOA     ilinux.io.      nsadmin.ilinux.io. (
       2017052301
       1H
       5M
       1W
       6H )
        IN      NS      dns1.ilinux.io.
        IN      NS      dns2.ilinux.io.
        IN    MX10  mx1.ilinux.io.
    dns1.ilinux.io. IN      A       172.16.252.35
    dns2.ilinux.io. IN      A       10.0.0.68
    mx1.ilinux.io.  IN    A    10.10.1.1
    www.ilinux.io.  IN      A       172.16.1.1
    web             IN      CNAME   www
    ftp    IN    A    172.16.0.111

  第二步:编辑bind辅助配置文件  

  vi /etc/named.rfc1912.zones
    ...(省略部分内容)
    #最后一行加入如下内容
    zone "ilinux.io" IN { 
    type master;
    file "ilinux.io.zone";
    };

 第三步:指定解析服务器IP

vi /etc/resolv.conf 
nameserver 172.16.252.35

 第四步:权限及属组修改(基于安全考虑)

  chmod o= /var/named/ilinux.io.zone 
  chown :named /var/named/ilinux.io.zone
  ls -l /var/named/ilinux.io.zone
  -rw-r-----. 1 root named 454 May 28 10:17 /var/named/ilinux.io.zone

    

 第五步:检查语法错误

named-checkconf
named-checkzone ilinux.io ilinux.io.zone 
zone ilinux.io/IN: loaded serial 2017052301     
OK                                         #验证正确

 第六步:重新加载解析数据库文件和配置文件 

  rndc reload
  server reload successful
  systemctl restart named.service

 第七步:测试域名解析  

dig www.ilinux.io 
    ; <<>> DiG 9.9.4-RedHat-9.9.4-37.el7 <<>> www.ilinux.io
    ;; global options: +cmd
    ;; Got answer:
    ;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 17242
    ;; flags: qr aa rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 2, ADDITIONAL: 3
    
    ;; OPT PSEUDOSECTION:
    ; EDNS: version: 0, flags:; udp: 4096
    ;; QUESTION SECTION:                #查询部分
    ;www.ilinux.io.INA
    
    ;; ANSWER SECTION:                  #回答部分
    www.ilinux.io.600INA172.16.1.1
    
    ;; AUTHORITY SECTION:               #权威解析部分
    ilinux.io.600INNSdns1.ilinux.io.
    ilinux.io.600INNSdns2.ilinux.io.
    
    ;; ADDITIONAL SECTION:              #附加信息部分
    dns1.ilinux.io.600INA172.16.252.35
    dns2.ilinux.io.600INA10.0.0.68
    
    ;; Query time: 1 msec
    ;; SERVER: 172.16.252.35#53(172.16.252.35)
    ;; WHEN: Sun May 28 11:16:29 CST 2017
    ;; MSG SIZE  rcvd: 128

    

2 反向解析

 步骤

  第一步:编辑解析数据库文件

vi /var/named/172.16.zone
    $TTL 1D
    @IN SOAilinux.io. nsadmin.ilinux.io. (
    2017052301; serial
    1D        ; refresh
    1H        ; retry
    1W        ; expire
    3H )    ; minimum
    
    @INNSdns1.ilinux.io.
    @INNSdns2.ilinux.io.
    35.252INPTRdns1.ilinux.io.
    68.0INPTRdns2.ilinux.io.
    1.1INPTRwww.ilinux.io.
    111.0INPTRftp.ilinux.io.

  第二步:编辑bind辅助配置文件

  vi /etc/named.rfc1912.zones
    #最后一行加入如下信息
    zone "16.172.in-addr.arpa" IN {
    type master;
    file "172.16.zone";
    };

  第三步:指定解析服务器IP

  vi /etc/resolv.conf 
    nameserver 172.16.252.35

  第四步:权限及属组修改(安全考虑)

chmod o= 172.16.zone 
chown :named 172.16.zone 
ll 172.16.zone 
-rw-r-----. 1 root named 298 May 28 10:58 172.16.zone

    

  第五步:检查语法错误

named-checkconf
named-checkzone 16.172.in-addr.arpa 172.16.zone 
zone 16.172.in-addr.arpa/IN: loaded serial 2017052301
OK              #验证成功

  第六步:重新加载解析数据库文件和配置文件

rndc reload
server reload successful
systemctl restart named.service

  第七步:测试域名解析    

dig -x 172.16.1.1 
    ; <<>> DiG 9.9.4-RedHat-9.9.4-37.el7 <<>> -x 172.16.1.1
    ;; global options: +cmd
    ;; Got answer:
    ;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 17034
    ;; flags: qr aa rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 2, ADDITIONAL: 3
    
    ;; OPT PSEUDOSECTION:
    ; EDNS: version: 0, flags:; udp: 4096
    ;; QUESTION SECTION:
    ;1.1.16.172.in-addr.arpa.INPTR
    
    ;; ANSWER SECTION:
    1.1.16.172.in-addr.arpa. 86400INPTRwww.ilinux.io.
    
    ;; AUTHORITY SECTION:
    16.172.in-addr.arpa.86400INNSdns1.ilinux.io.
    16.172.in-addr.arpa.86400INNSdns2.ilinux.io.
    
    ;; ADDITIONAL SECTION:
    dns1.ilinux.io.600INA172.16.252.35
    dns2.ilinux.io.600INA10.0.0.68
    
    ;; Query time: 0 msec
    ;; SERVER: 172.16.252.35#53(172.16.252.35)
    ;; WHEN: Sun May 28 11:45:36 CST 2017
    ;; MSG SIZE  rcvd: 149

3 主从DNS服务器配置(包含正反向域名解析)

 步骤

  第一步:编辑bind辅助配置文件

    1.DNS主服务器正反向解析文件配置上面已有配置,不再介绍

    2.DNS从服务器正反向解析区域配置文件

        环境:centos6.8 IP:10.0.0.68 DNS主机名:dns2.ilinux.io

vi /etc/named.rfc1912.zones  
        #最后一行加入如下信息
        zone "ilinux.io" IN {
            type slave;
            file "slaves/ilinux.io.zone";
            masters { 172.16.252.35; };
        };
        
        zone "16.172.in-addr.arpa" IN {
                type slave;
                file "slaves/172.16.zone";
                masters { 172.16.252.35; };
        };

  第二步:检查语法错误

   named-checkconf

    

  第三步:重新加载配置文件

  rndc reload
    server reload successful
    systemctl restart named.service

    

  第四步:查看是否配置成功

  cat /var/log/messages | grep "Transfer completed"
    May 28 08:46:20 localhost named[2224]: transfer of 'ilinux.io/IN' from 172.16.252.35#53: Transfer completed: 1 messages, 11 records, 271 bytes, 0.002 secs (135500 bytes/sec)
    May 28 08:54:58 localhost named[2224]: transfer of '16.172.in-addr.arpa/IN' from 172.16.252.35#53: Transfer completed: 1 messages, 7 records, 227 bytes, 0.004 secs (56750 bytes/sec)

    

第五步:测试从服务域名解析

  正向解析测试
    [root@god named]#dig www.ilinux.io @10.0.0.68
    ; <<>> DiG 9.8.2rc1-RedHat-9.8.2-0.47.rc1.el6 <<>> www.ilinux.io @10.0.0.68
    ;; global options: +cmd
    ;; Got answer:
    ;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 51468
    ;; flags: qr aa rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 2, ADDITIONAL: 2
    
    ;; QUESTION SECTION:
    ;www.ilinux.io.INA
    
    ;; ANSWER SECTION:
    www.ilinux.io.600INA172.16.1.1
    
    ;; AUTHORITY SECTION:
    ilinux.io.600INNSdns2.ilinux.io.
    ilinux.io.600INNSdns1.ilinux.io.
    
    ;; ADDITIONAL SECTION:
    dns1.ilinux.io.600INA172.16.252.35
    dns2.ilinux.io.600INA10.0.0.68
    
    ;; Query time: 1 msec
    ;; SERVER: 10.0.0.68#53(10.0.0.68)
    ;; WHEN: Sun May 28 10:51:34 2017
    ;; MSG SIZE  rcvd: 117

    反向解析测试

dig -x 172.16.1.1 @10.0.0.68
    ; <<>> DiG 9.8.2rc1-RedHat-9.8.2-0.47.rc1.el6 <<>> -x 172.16.1.1 @10.0.0.68
    ;; global options: +cmd
    ;; Got answer:
    ;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 21780
    ;; flags: qr aa rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 2, ADDITIONAL: 2
    
    ;; QUESTION SECTION:
    ;1.1.16.172.in-addr.arpa.INPTR
    
    ;; ANSWER SECTION:
    1.1.16.172.in-addr.arpa. 86400INPTRwww.ilinux.io.
    
    ;; AUTHORITY SECTION:
    16.172.in-addr.arpa.86400INNSdns2.ilinux.io.
    16.172.in-addr.arpa.86400INNSdns1.ilinux.io.
    
    ;; ADDITIONAL SECTION:
    dns1.ilinux.io.600INA172.16.252.35
    dns2.ilinux.io.600INA10.0.0.68
    
    ;; Query time: 0 msec
    ;; SERVER: 10.0.0.68#53(10.0.0.68)
    ;; WHEN: Sun May 28 10:49:23 2017
    ;; MSG SIZE  rcvd: 138

4 总结

    本文中DNS域名解析服务是基于bind来实验操作的。

    文中仅分享了如何配置DNS域名解析服务,至于配置bind服务中相关的知识点可以参考如下:

    https://www.isc.org/downloads/bind/doc/ 官方文档

    《鸟哥的Linux私房菜服务器架设篇(第三版)》

    

    本文实验包含DNS正向解析服务部署,DNS反向解析服务部署,DNS主从服务部署。

    想要掌握DNS域名解析服务,深刻了解DNS域名解析知识必不可少,多多动手操作配置服务必不可少。

原创文章,作者:EMKKT,如若转载,请注明出处:http://www.wangzhanshi.com/n/14945.html

(0)
EMKKT的头像EMKKT
上一篇 2025年1月1日 17:05:59
下一篇 2025年1月1日 17:06:01

相关推荐

  • 如何应对高并发

    #高并发应对方案 架构方面 分层 对系统架构的分层,分为展示层,业务层,服务层,数据层等,可以使得分工明确,实现解耦,便于管理 按业务种类分层,可以实现服务化,解耦。 分布式(即模…

    DNS解析 2025年1月1日
  • 如何搭建简易DNS服务器

    简易DNS服务器 domain name server,dns协议,其实现软件主要是bind.bind软件由配置文件和区域数据文件组成。 区域数据库文件,主要是用来记录资源记录的。…

    DNS解析 2025年1月1日
  • cmd DNS解析缓存

    dns解析缓存:ipconfig /flushdns查看所有ip:ipconfig/all

    DNS解析 2025年1月1日
  • 基于DHCP+DNS+WEB的小型架构

    案例前的准备:电脑中需要安装VMware虚拟机,此处附链接供实验下载:链接:https://pan.baidu.com/s/1V06orbCIXc7IY6oNNscJiQ 提取码:…

    2025年1月1日
  • 如何进行DNS欺骗的分析

    一.什么是DNS欺骗? DNS欺骗是一门改变DNS原始指向IP的艺术。 什么是DNSomain Name Server 域名服务器 域名虽然便于人们记忆,但网络中的计算机之间只能互…

    DNS解析 2025年1月1日
  • Linux下DNS服务器架设方法

    一、 相关知识概述    DNS(Domain Name System)即域名服务系统,作用为完成域名与IP地址的互换。网络上的每一台主机都有一个域名…

    DNS解析 2025年1月1日
  • windows默认网关和dns如何设置

    默认网关和dns设置的详细教程 第一步:打开网络管理中心,选择以太网,点击更改适配器选项。 第二步:右击以太网(本地连接),选择属性。 第三步:找到协议版本4,双击。 第四步:把自…

    2025年1月1日
  • 怎么修复win7系统dns异常问题

    修复win7系统dns异常方法/步骤: 1.打开win7系统下的网络和共享中心界面,随后选择“更改适配器”进入。 2.直接在界面中右键选中本地连接选项。 3.开始打开对应的属性窗口…

    2025年1月1日
  • DNS工作原理讲解

        我们通常使用域名来访问目标机器,而不是直接使用其IP地址,那么域名与IP地址之间存在什么样子的转化关系呢?想要了解他们之间的转化关系…

    2025年1月1日
  • Linux系统中怎么修改DNS地址

    1.修改主机名 代码如下: #hostname Slyar 2.修改IP地址(eth0为网卡名称) 代码如下: #ifconfig eth0 192.168.1.5 netmask…

    2025年1月1日

发表回复

登录后才能评论