linux基础服务之DNS

一、DNS简介

1DNSDomain Name System(域名系统),是互联网上IP和域名相互解析的分布式层级结构的数据库。DNS的出现能够使用户更好的更加方便的访问互联网,不用记IP地址来访问互联网,可以通过人类更容易记住域名来访问互联网。

2DNS是一种C/S架构的服务器,客户机用于一个名字对应的地址,而服务器是为客户机提供查询的,查询由两种机制:迭代查询和递归查询

   迭代查询:一般是DNS服务器与DNS服务器之间的查询方式

   递归查询:一般是客户机与服务器之间的查询方式

3、DNS是通过解析记录来过建成的DNS数据库,数据库中解析记录又分为正向解析和反向解析。其中正向解析是从域名到IP的过程,而反向解析是从IP到域名的过程。那么解析记录主要有哪些呢?

       常见的记录:

             A:就是地址(address)的缩写,后面记录的是ipv4的地址

             AAAA:对应的是Iipv6的地址

             NS:后面对应的是DNS服务器

             SOA:就是开始验证(start of autority)的缩写

             PTR:后面对应的是反向解析到的主机名

             CNAME:主机别名,一个主机可以有多个主机名。

             MAX:邮件服务器的地址

      下面我们通过几个简单的配置来认识DNS服务

二、正向解析的配置

 

   以zhanglangcom域为例用ns1.zhanglang.com服务器:

   实验前准备:安装bind软件包

      yum install bind

   (1) 定义区域

     在主配置文件中(/etc/named.conf)或主配置文件辅助配置文件(/etc/named.rfc1912.conf)中实现;

     修改主配置文件 vim /etc/named.conf

      linux基础服务之DNS     

   

    修改/etc/named.rfc1912.conf,添加zone(在/var/named/*.zone的文件)

     linux基础服务之DNS  

  

   (2) 建立区域数据文件(主要记录为AAAAA记录)

     /var/named目录下建立区域数据文件;

     文件为:/var/named/zhanglang.com.zone

     linux基础服务之DNS

  

   (3)权限及属组修改:

     # chown  :named  /var/named/zhanglang.com.zone

     # chmod  o=  r/named/zhanglang.com.zone

   (4)检查语法错误:

      linux基础服务之DNS

   (5)让服务器重载配置文件和区域数据文件

      # rndc  reload

   (6)测试

     linux基础服务之DNS

     正向解析配置成功

二、配置解析一个反向区域

  (1) 定义区域

    在主配置文件中或主配置文件辅助配置文件中实现;

    修改主配置文件 vim /etc/named.conf

    linux基础服务之DNS

   修改/etc/named.rfc1912.conf,添加zone(在/var/named/*.zone的文件)

    linux基础服务之DNS

  (2) 定义区域解析库文件(主要记录为PTR)vim /var/named/192.168.zone

    linux基础服务之DNS

 (3)权限及属组修改:

    # chgrp  named  /var/named/192.168.zone

    # chmod  o=  /var/named/192.168.zone

 (4)检查语法错误和重载:

    # named-checkzone  168.192.in-addr.arpa /var/named/192.168.zone

    # named-checkconf

    # rndc reload 

 (5)测试

           linux基础服务之DNS    

三、主从服务器:

       在示例一我们以ns1.zhanglang.com做了正向解析主服务器,那么我们再以ns2.zhanglang.com作从服务器,我们直接修改ns2.zhanglang.com配置就行了。如下:

       (1)修改配置文件

              修改主配置文件 vim /etc/named.conf

              linux基础服务之DNS 

       (2)定义区域 vim  /etc/named.rfc1912.conf

              linux基础服务之DNS

       (3)检查语法错误和重载:

      # named-checkconf

               # rndc reload

               linux基础服务之DNS

       (4)测试

            在从服务器上解析

               linux基础服务之DNS

           解析成功

四、子域

        正向解析区域授权子域的方法:

  父域配置

   (1) /var/named目录下建立区域数据文件;vim /var/named/zhanglang.com.zone

                linux基础服务之DNS

   (2)检查语法错误和重载:

                 # named-checkzone  zhanglang.com /var/named/zhanglang.com.zone

     # named-checkconf

                 # rndc reload

        子域配置

            1)在子域配置

      主配置文件(开启监听端口vim /etc/named.conf

                   linux基础服务之DNS

                创建域vim /etc/named.rfc1912.zones

                linux基础服务之DNS  

         (3)创建域解析库  vim /var/named/ops.zhanglang.com.zone

     linux基础服务之DNS

   (4)修改权限和组

     linux基础服务之DNS

   (5)检查语法错误和重载:

      # named-checkzone  ops.zhanglang.com /var/named/ops.zhanglang.com.zone

       # named-checkconf

       # rndc reload

   (6)检测

      子域检查

        linux基础服务之DNS

     父域检测

        linux基础服务之DNS

     成功配置子域授权

五、定义转发(在子域定义转发):

注意:被转发的服务器必须允许为当前服务做递归

 在上例中的子域服务器配置转发 

  (1) 配置文件 /etc/named.rfc1912.zones 

    linux基础服务之DNS

 (2)语法检查和重载

    linux基础服务之DNS

 (3) 检测

    检测父域“zhanglang.com”

     linux基础服务之DNS

     解析成功

六、基本安全控制

   acl:访问控制列表;把一个或多个地址归并一个命名的集合,随后通过此名称即可对此集全内的所有主机实现统一调用;

     bind有四个内置的acl

       none:没有一个主机;

       any:任意主机;

       local:本机;

       localnet:本机的IP所属的网络;

        常见访问控制指令

     allow-query  {};  允许查询的主机;白名单;

     allow-transfer {};  允许向哪些主机做区域传送;默认为向所有主机;应该配置仅允许从服务器;

     allow-recursion {}; 允许哪此主机向当前DNS服务器发起递归查询请求;

     allow-update {}; DDNS,允许动态更新区域数据库文件中内容;

        1、allow-query 在主服务器上(ns1.zhanglang.com)

            (1)  主配置文件vim /etc/named.conf 创建访问控制列表(控制为只能192.168.109.101主机能解析)

       linux基础服务之DNS

    (2) 创建域vim /etc/named.rfc1912.zones

      linux基础服务之DNS

    (3)与法检测和重载

      linux基础服务之DNS

   (4)检测(测试时所用的命令和服务器地址一致

     192.168.109.101检测

      linux基础服务之DNS

      解析成功

    192.168.109.100检测

      linux基础服务之DNS

      解析失败,控制设置成功

            2、allow-transfer 在主服务器上(ns1.zhanglang.com)

                 (1) 主配置文件vim /etc/named.conf 创建访问控制列表(控制为只能192.168.109.100主机只能区域传输)

        linux基础服务之DNS

     (2) 创建域vim /etc/named.rfc1912.zones

        linux基础服务之DNS

                 (3)与法检测和重载

        linux基础服务之DNS

     (4)测试

       192.168.109.101检测

         linux基础服务之DNS

        传输失败

       192.168.109.100测试

         linux基础服务之DNS

       传送成功,控制设置成功

     3、allow-recursion 在主服务器上(ns1.zhanglang.com)

       (1) 主配置文件vim /etc/named.conf 创建访问控制列表(控制为只能192.168.109.101/24网段递归

          linux基础服务之DNS

      (2)与法检测和重载

          linux基础服务之DNS

      (4)测试

       192.168.109.101检测

          linux基础服务之DNS

        成功

      4、 allow-update {}; DDNS,允许动态更新区域数据库文件中内容;

         一般我们是不允许动态更新区域数据库文件中内容;因为允许动态更新区域数据库文件中内容会造成安全风险;所以我们禁止动态更新

         编辑配置文件:vim /etc/named.rfc1912.zones

            在每个zone中加上 allow-update { none; };即可

           linux基础服务之DNS  

          然后重载服务就可以了

          linux基础服务之DNS    

            

        

    

   

   

 


 

原创文章,作者:zq,如若转载,请注明出处:http://www.178linux.com/77064

(0)
zqzq
上一篇 2017-05-29 12:31
下一篇 2017-05-29 16:42

相关推荐

  • 第二十一周作业

    1、回顾并详细总结MySQL的存储引擎、索引; 常用存储引擎的对比: 特点 MyISAM InnoDB MEMORY MERGE NDB 存储限制 有 64TB 有 没有 有 事务安全 支持 锁机制 表锁 行锁 表锁 表锁 行锁 B树索引 支持 支持 支持 支持 支持 哈希索引 支持 全文索引 支持 集群索引 支持 数据缓存 支持 支持 支持 索引缓存 支持…

    2017-07-29
  • 组建RAID5重启系统,出现md127的解决办法

        我这里在组建RAID5之后重启了系统,当时/dev/md0变成了/dev/md127。出现这问题主要是我没有配置生成/etc/mdadm.conf文件,如果哪位伙伴出现类似我这种情况,而不是通过我这种方法解决的,希望能分享一下你的解决方法,谢谢。  先停止md127 [root@client3&nbs…

    Linux干货 2016-01-05
  • Linux破解root口令

    Centos5、6版本破解口令方法 1 启动系统 2 在操作系统选择菜单界面选中要启动的内核 — 按a键 3 在行尾输入 1(或s或S或single)— 按回车键 4 使用passwd命令修改口令即可   Centos7版本破解口令方法 方法1 1 启动系统 2 在操作系统选择菜单界面选中要启动的内核 — 按e键…

    Linux干货 2018-01-08
  • 树 非线性结构 树是n(n >= 0)个元素的集合: (1)每个元素称为结点(node); (2)有一个特定的结点,称为根结点或根(root); (3)除根结点外,其余结点被分成m(m>=0)个互不相交的有限集合,而每个子集又都是一棵树(称为原树的子树Subtree) 注意 n = 0时,称为空树 树只有一个特殊的没有前驱的元素,称为树的根(Ro…

    2017-10-16
  • 计算机浅谈及Linux简谈

    一、计算机浅谈: 电子计算机(英语:computer),亦称电脑,是一种利用电子学原理,根据一系列指令对数据进行处理的工具。 在现代,机械计算机的应用已经完全被电子计算机所替换,其所相关的技术研究叫计算机科学,而“计算机技术”指的是将计算机科学的成果应用于工程实践所派生的诸多技术性和经验性成果的总合。“计算机技术”与“计算机科学”是两个相关而又不同的概念,它…

    Linux干货 2016-11-29
  • 恐怖的C++语言

    Linus曾经(2007年9月)在新闻组gmane.comp.version-control.git里和一个微软的工程师(Dmitry Kakurin)争执过用C还是用C++,当时的那个微软的工程师主要是在做Git的Windows版,但他却发现Git的源码居然是C语言写的,而不是C++,于是他(Dmitry Kakurin)在Linux社区里发贴表示对Lin…

    Linux干货 2015-04-03