zoukankan      html  css  js  c++  java
  • DNS服务搭建

    一、DNS基础

      域名系统(DNS)是一个层次化得分布式数据库。存储用于互联网主机名与IP地址相映射的信息,邮件路由信息,及其它互联网应用所用到的数据。DNS(Domain Name System,域名系统),因特网上作为域名和IP地址相互映射的一个分布式数据库,能够使用户更方便的访问互联网,而不用去记住能够被机器直接读取的IP数串。通过主机名,最终得到该主机名对应的IP地址的过程叫做域名解析(或主机名解析)。DNS协议运行在UDP协议之上,使用端口号53。

      客户端通过调用一个解析器库来在DNS 中查找信息,解析器向一个或多个名字服务器发出请求并解释响应。BIND 9软件分发包中包括一个名字服务器,named,和一个解析器库,liblwres。旧的libbind解析器库也可以作为一个单独的下载包从ISC得到。

    二、DNS功能

      每个IP地址都可以有一个主机名,主机名由一个或多个字符串组成,字符串之间用小数点隔开。有了主机名,就不要死记硬背每台IP设备的IP地址,只要记住相对直观有意义的主机名就行了。这就是DNS协议所要完成的功能。
    主机名到IP地址的映射有两种方式:
    1)静态映射,每台设备上都配置主机到IP地址的映射,各设备独立维护自己的映射表,而且只供本设备使用;
    2)动态映射,建立一套域名解析系统(DNS),只在专门的DNS服务器上配置主机到IP地址的映射,网络上需要使用主机名通信的设备,首先需要到DNS服务器查询主机所对应的IP地址
    通过主机名,最终得到该主机名对应的IP地址的过程叫做域名解析(或主机名解析)。在解析域名时,可以首先采用静态域名解析的方法,如果静态域名解析不成功,再采用动态域名解析的方法。可以将一些常用的域名放入静态域名解析表中,这样可以大大提高域名解析效率。

     三、域名结构

      通常 Internet 主机域名的一般结构为:主机名.三级域名.二级域名.顶级域名。 Internet 的顶级域名由 Internet网络协会域名注册查询负责网络地址分配的委员会进行登记和管理,它还为 Internet的每一台主机分配唯一的 IP 地址。全世界现有三个大的网络信息中心: 位于美国的 Inter-NIC,负责美国及其他地区; 位于荷兰的RIPE-NIC,负责欧洲地区;位于日本的APNIC ,负责亚太地区

    四、搭建DNS服务器

    环境:CentOS Linux release 7.4.1708 (Core)

    关闭iptables和selinux

    1)安装(bind主要软件,bind-util提供测试工具,bind-chroot提供一个伪装的根目录以增强安全性(将“/var/named/chroot/”文件夹作为BIND的根目录)
    [root@controller ~]# yum -y install bind bind-chroot bind-util bind-libs
    
    2)DNS配置
    #备份
    [root@controller ~]# cp /etc/named.conf{,.bak}
    #修改配置
    [root@controller ~]# vim   /etc/named.conf
    //
    // named.conf
    //
    #options 控制全局服务配置和为其它语句设置缺省参数。
    options {
            listen-on port 53 { any; };    #监听端口53,默认监听127.0.0.1,修改为any允许任意主机,注意{}一定要空格
            listen-on-v6 port 53 { ::1; };  #监听ipv6的IP地址选项
            directory       "/var/named";     #DNS的根目录,由于安装了bind-chroot的所致,因此服务的实际工作目录为/var/named/chroot/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     { any; };  #允许查询的主机,默认为localhost,这里修改为any
            recursion yes;    #开启递归查询
    
            dnssec-enable yes;
            dnssec-validation yes;
    
            /* Path to ISC DLV key */
            bindkeys-file "/etc/named.iscdlv.key";
    
            managed-keys-directory "/var/named/dynamic";
    
            pid-file "/run/named/named.pid";
            session-keyfile "/run/named/session.key";
    };
    #logging 指定服务器纪录哪些日志,和在哪里纪录日志消息
    logging {
            channel default_debug {
                    file "data/named.run";
                    severity dynamic;
            };
    };
    #zone 定义一个区
    zone "." IN {
            type hint;
            file "named.ca";
    };
    
    include "/etc/named.rfc1912.zones";
    include "/etc/named.root.key";
    
    #授权
    [root@controller var]# chmod 770 /var/named/
    #启动服务
    [root@controller var]# service named start
    [root@controller var]# ss -lnt|grep 53
    LISTEN     0      10     172.17.0.1:53                       *:*   
    
    3)客户机测试
    修改resolve.conf文件添加dns服务器ip
    [root@lvs_m ~]# cat /etc/resolv.conf 
    # Generated by NetworkManager
    nameserver 192.168.128.169
    
    [root@lvs_m ~]# nslookup
    > www.baidu.com
    Server:         192.168.128.169
    Address:        192.168.128.169#53
    
    Non-authoritative answer:
    www.baidu.com   canonical name = www.a.shifen.com.
    Name:   www.a.shifen.com
    Address: 14.215.177.38
    Name:   www.a.shifen.com
    Address: 14.215.177.39
    
    4)添加自定义域名
    1、修改/etc/named.conf文件添加如下内容
    ...
    zone "www.baidu.com" IN {                #正向解析,指定区域
            type master;                         #服务器类型,master为主域名
            file "www.baidu.com_zone";           #正向解析区域文件名www.baidu.com_zone,在/var/named目录下创建
            allow-transfer {192.168.128.171;};    #从DNS服务器地址
    };
    
    zone "128.168.192.in-addr.arpa" IN {      #反向解析,ip段为192.168.128.0/24 反写
            type master;
            file "192.168.128.zone";          #反向解析文件名
            allow-transfer {192.168.128.171;};
    };
    #检查语法这点很重要,不然服务会出错。
    [root@controller ~]# named-checkconf 
    #创建域文件
    $TTL 180
    @       IN SOA  yxb.qq.com. root.www.baidu.com. ( ;
                                            0       ; serial
                                            1D      ; refresh
                                            1H      ; retry
                                            1W      ; expire
                                            44H )    ; minimum
    @       IN      NS     ns1.www.baidu.com.      ;
    ns1.www.baidu.com.    IN  A   192.168.128.169
    www.baidu.com. IN A 192.168.128.211    #添加A纪录可以是多个地址             
    www.baidu.com. IN A 192.168.128.212
    
    #创建反向解析域文件
    [root@controller ~]# cat /var/named/192.168.128.zone 
    $TTL 180
    @       IN SOA  yxb.qq.com. root.www.baidu.com. ( ;
                                            0       ; serial
                                            1D      ; refresh
                                            1H      ; retry
                                            1W      ; expire
                                            44H )    ; minimum
    @       IN      NS     ns1.www.baidu.com. 
    169 IN PTR ns1.www.baidu.com.
    211 IN PTR www.baidu.com.
    212 IN PTR www.baidu.com.
    #检查语法
    [root@controller ~]# named-checkzone www.baidu.com /var/named/www.baidu.com_zone 
    zone www.baidu.com/IN: loaded serial 0
    OK
    #重启dns服务
    [root@controller ~]# service named restart 
    
    #客户机测试
    [root@lvs_m ~]# dig www.baidu.com
    
    ; <<>> DiG 9.8.2rc1-RedHat-9.8.2-0.62.rc1.el6 <<>> www.baidu.com
    ;; global options: +cmd
    ;; Got answer:
    ;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 64633
    ;; flags: qr aa rd ra; QUERY: 1, ANSWER: 2, AUTHORITY: 1, ADDITIONAL: 1
    
    ;; QUESTION SECTION:
    ;www.baidu.com.                 IN      A
    
    ;; ANSWER SECTION:
    www.baidu.com.          180     IN      A       192.168.128.212
    www.baidu.com.          180     IN      A       192.168.128.211
    
    ;; AUTHORITY SECTION:
    www.baidu.com.          180     IN      NS      ns1.www.baidu.com.
    
    ;; ADDITIONAL SECTION:
    ns1.www.baidu.com.      180     IN      A       192.168.128.169
    
    ;; Query time: 1 msec
    ;; SERVER: 192.168.128.169#53(192.168.128.169)
    ;; WHEN: Thu Nov 23 00:52:38 2017
    ;; MSG SIZE  rcvd: 97
    
    5)DNS从服务器配置,只需配置/etc/named.conf文件不需要添加域文件
    软件安装:
    [root@lvs_m ~]# yum -y install bind bind-chroot bind-util bind-libs
    #修改配置文件
    [root@lvs_m ~]# vim /etc/named.conf
    options {
            listen-on port 53 { any; };
            listen-on-v6 port 53 { ::1; };
            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     { any; };
            recursion yes;
    
            dnssec-enable yes;
            dnssec-validation yes;
    
            /* Path to ISC DLV key */
            bindkeys-file "/etc/named.iscdlv.key";
    
            managed-keys-directory "/var/named/dynamic";
    };
    
    logging {
            channel default_debug {
                    file "data/named.run";
                    severity dynamic;
            };
    };
    
    zone "." IN {
            type hint;
            file "named.ca";
    };
    zone "www.baidu.com" IN {
            type slave;                         #类型设置为slave
            file "www.baidu.com_zone";
            masters { 192.168.128.169; };              #主服务器ip
    };
    
    zone "128.168.192.in-addr.arpa" IN {
            type slave;
            file "192.168.128.zone";
            masters { 192.168.128.169; };
    };
    include "/etc/named.rfc1912.zones";
    include "/etc/named.root.key";
    
    [root@lvs_m ~]# chmod 770 /var/named/
    [root@lvs_m ~]# ll /var/named/ -d
    drwxrwx---. 6 root named 4096 Nov 23 01:07 /var/named/
    [root@lvs_m ~]# named-checkconf 
    [root@lvs_m ~]# service named restart
    
    #测试
    [root@controller ~]# dig www.baidu.com @192.168.128.171
    
    ; <<>> DiG 9.9.4-RedHat-9.9.4-51.el7 <<>> www.baidu.com @192.168.128.171
    ;; global options: +cmd
    ;; Got answer:
    ;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 23616
    ;; flags: qr aa rd ra; QUERY: 1, ANSWER: 2, AUTHORITY: 1, ADDITIONAL: 2
    
    ;; OPT PSEUDOSECTION:
    ; EDNS: version: 0, flags:; udp: 4096
    ;; QUESTION SECTION:
    ;www.baidu.com.                 IN      A
    
    ;; ANSWER SECTION:
    www.baidu.com.          180     IN      A       192.168.128.211
    www.baidu.com.          180     IN      A       192.168.128.212
    
    ;; AUTHORITY SECTION:
    www.baidu.com.          180     IN      NS      ns1.www.baidu.com.
    
    ;; ADDITIONAL SECTION:
    ns1.www.baidu.com.      180     IN      A       192.168.128.169
    
    ;; Query time: 226 msec
    ;; SERVER: 192.168.128.171#53(192.168.128.171)      //成功
    ;; WHEN: Thu Nov 23 04:36:22 EST 2017
    ;; MSG SIZE  rcvd: 108
    

  • 相关阅读:
    SSE图像算法优化系列十七:多个图像处理中常用函数的SSE实现。
    SSE图像算法优化系列十六:经典USM锐化中的分支判断语句SSE实现的几种方法尝试。
    Tone Mapping算法系列二:一种自适应对数映射的高对比度图像显示技术及其速度优化。
    SSE图像算法优化系列十五:YUV/XYZ和RGB空间相互转化的极速实现(此后老板不用再担心算法转到其他空间通道的耗时了)。
    Android项目之JSON解析(3种解析技术详解)
    Android 图片文字识别DEMO(基于百度OCR)
    再谈如何将android studio项目转换成eclipse
    集成百度OCR
    异步任务AsyncTask使用解析
    Nginx+IIS,Asp.Net 服务器配置
  • 原文地址:https://www.cnblogs.com/Dev0ps/p/7883776.html
Copyright © 2011-2022 走看看