20170921 DNS服务(二)

作者: 哈喽别样 | 来源:发表于2017-09-25 14:27 被阅读11次
  • bind view
  • 编译安装bind
  • DNS排错

一、bind view

(一)智能DNS

  • 智能DNS:DNS服务器根据客户端主机所在地区,分配给客户端所在区域代理服务器地址,代理服务器中缓存了客户想要访问网站的静态内容,从而提高了访问的速度

  • 区域代理服务器:CDN服务

(二)bind view

(1) view:视图
  • 每个view用来匹配一组客户端
  • 一个bind服务器可定义多个view,每个view中可定义一个或多个zone,每个zone也可以包含在一个或多个view中
  • 多个view内可能需要对同一个区域进行解析,但使用不同的区域解析库文件
  • 语法:
view VIEW_NAME {
match-clients { testacl; };
zone "magedu.com" IN {
  type master;
  file "magedu.com.zone";};
  include "/etc/named.rfc1912.zones";
};
  • 注意:
    (1)一旦启用了view,所有的zone都只能定义在view中
    (2)仅在允许递归请求的客户端所在view中定义根区域
    (3)客户端请求到达时,是自上而下检查每个view所服务的客户端列表
(2)实验:实现不同网段的客户端对同一个主机的DNS查询请求分配不同的IP
  • 分析:view的建立需要以下几个条件:
    (1)分别声明不同的网段;
    (2)给每个view匹配网段;
    (3)每个view中包含相关的区域设置和区域解析库文件。

  • 第1步,编辑/etc/named.conf文件,配置如下:

acl beijing_net {
        192.168.136.0/24;                  //定义此acl为北京地区的iP
};

acl henan_net {
        172.18.0.0/16;                     //定义此acl为河南地区的iP
};

view beijing_view {
        match-clients {beijing_net;};      //匹配北京的acl
        include "/etc/named.rfc1912.zones.bj";
};

view henan_view {
        match-clients {henan_net;};        //匹配河南的acl
        include "/etc/named.rfc1912.zones.hn";
};
  • 第2步,编辑独立区域配置文件
cp -p /etc/named.rfc1912.zones /etc/named.rfc1912.zones.bj
cp -p /etc/named.rfc1912.zones /etc/named.rfc1912.zones.hn
rm -f /etc/named.rfc1912.zones
vim /etc/named.rfc1912.zones.bj     //以下为文件增加内容

zone "hellopeiyang.com" IN {
        type master;
        file "hellopeiyang.com.zone.bj";     //由此看到之后要修改解析库文件
};

zone "." IN {    
        type hint;
        file "named.ca";
//根区域设置原保存在/etc/named.conf文件中,但是由于定义view后所有zone都要定义在zone中,
  而beijing_view和henan_view都需要包含根区域,故将此设置迁移到独立设置文件中,
  也可以在两个view中分别定义根区域设置

vim /etc/named.rfc1912.zones.hn          //以下为文件增加内容

zone "hellopeiyang.com" IN {
        type master;
        file "hellopeiyang.com.zone.hn";
};

zone "." IN {
        type hint;
        file "named.ca";
  • 第3步,编辑解析库文件
cp -p /var/named/hellopeiyang.com.zone  /var/named/hellopeiyang.com.zone.bj
cp -p /var/named/hellopeiyang.com.zone  /var/named/hellopeiyang.com.zone.hn
vim /var/named/hellopeiyang.com.zone.bj

$TTL 1D
@       IN SOA  dns1 admin.hellopeiyang.com. (
                                        101     ; serial
                                        1D      ; refresh
                                        1H      ; retry
                                        1W      ; expire
                                        3H )    ; minimum
        NS      dns1
dns1    A       192.168.136.230
websrv  A       192.168.136.229     //来自192.168.136.0/24网段的主机应该返回的ip
www     CNAME   websrv

vim /var/named/hellopeiyang.com.zone.hn

$TTL 1D
@       IN SOA  dns1 admin.hellopeiyang.com. (
                                        101     ; serial
                                        1D      ; refresh
                                        1H      ; retry
                                        1W      ; expire
                                        3H )    ; minimum
        NS      dns1
dns1    A       192.168.136.230
websrv  A       172.18.0.66        //来自172.18.0.0/16网段的主机应该返回的ip    
www     CNAME   websrv
  • 第4步,检查语法并重新载入配置
named-checkconf
named-checkzone hellopeiyang.com /var/named/hellopeiyang.com.zone.bj
named-checkzone hellopeiyang.com /var/named/hellopeiyang.com.zone.hn
rndc reload
  • 第5步,测试
    dig www.hellopeiyang.com @192.168.136.230

dig www.hellopeiyang.com @172.18.250.79

二、编译安装bind

(一)安装前准备

  • 安装开发环境:
    yum groupinstall "development tools"
  • 下载源码包并解压缩:
    tar xvf /usr/src/bind-9.10.6.tar.gz
    cd /usr/src/bind-9.10.6
  • 添加named用户和组
    useradd -r -m -d /var/named -s /sbin/nologin named

(二)编译安装过程

  • 检查安装环境并生成makefile
    ./configure --prefix=/app/bind9 --sysconfdir=/etc/bind9 --without-openssl
  • 编译源码包
    make -j2
  • 安装
    make install

(三)编译安装后配置

  • 配置根区域解析文件
    dig -t ns . @172.18.0.1 > /app/named.ca
    scp /app/named.ca 192.168.136.129:/var/named
    使用dig命令生成解析信息重定向为named.ca文件,并传送到正在安装bind的主机相应目录下

  • 配置环境变量

vim /etc/profile.d/env.sh
export PATH=/app/bind9/bin:/app/bind9/sbin:$PATH

source /etc/profile.d/env.sh
  • 创建主配置文件
vim /etc/bind9/named.conf

options {
        directory "/var/named/";
};

zone "." IN {
        type hint;
        file "named.ca";
};
zone "test.com" IN {
        type master;
        file "test.com.zone";
};

  • 创建区域解析库文件
vim /var/named/test.com.zone

$TTL 1d
@       IN      SOA     dns1 admin ( 101 1d 8h 1w 1d )
                NS      dns1
dns1            A       192.168.136.129
www             A       192.168.6.6
  • 配置man帮助
vim /etc/man.config
MANPATH /app/bind9/share/man    //添加一行

man named.conf                  //查看named.conf配置文件帮助

(四)启动bind

chown root:named /var/named/* /etc/bind9/named.conf
修改文件权限
named -u named -f -g -d 3
前端以级别3方式运行,-f:前台运行,-g 日志显示在标准错误输出即屏幕,-d:排错级别 debug_level

成功启动后,测试成功,并且也看到了日志记录

(五)rndc的配置

(1)rndc命令(TCP 953端口)

语法:rndc COMMAND

COMMAND
status:查询当前状态
reload:重载主配置文件和区域解析库文件
reload zonename:重载区域解析库文件
retransfer zonename:手动启动区域传送,而不管序列号是否增加
notify zonename:重新对区域传送发通知
reconfig:重载主配置文件
querylog:开启或关闭查询日志文件/var/log/message
trace:递增debug一个级别
trace LEVEL:指定使用的级别
notrace:将调试级别设置为0
flush:清空DNS服务器的所有缓存记录
(2)配置rndc

直接使用rndc的相关命令发现不可用,提示rndc: neither /etc/bind9/rndc.conf nor /etc/bind9/rndc.key was found。由于rndc属于客户端工具,修改named服务的配置时,需要生成预共享秘钥,实现与服务器端的通讯。

  • 生成预共享秘钥:rndc-confgen -r /dev/urandom > /etc/bind9/rndc.conf

打开/etc/bind9/rndc.conf文件,发现提示将蓝色注释行的设置信息添加到/etc/bind9/named.conf文件中

vim /etc/bind9/named.conf     //添加以下内容

key "rndc-key" {
        algorithm hmac-md5;
        secret "V+GtFM3bQjW7n3zU8OFB6g==";
 };
 
controls {
        inet 127.0.0.1 port 953
                allow { 127.0.0.1; } keys { "rndc-key"; };
 };

重新启动named服务,rndc命令成功运行,bind的安装基本结束

(六)压力测试

(1)编译安装压力测试工具queryperf
cd /usr/src/bind-9.10.6/contrib/queryperf     //进入工具的源代码目录
./configure                     //生成makefile
make                            //编译
cp queryperf /app/bind9/bin     //复制编译生成的二进制文件至bind的二进制文件安装目录
(2)queryperf工具的使用

queryperf -d test.txt -s 127.0.0.1-d 测试文件, -s DNS服务器IP

三、DNS排错

  • SERVFAIL错误:server fail
    服务器遇到错误,可使用dig +trace排错,可能是网络和防火墙导致

  • NXDOMAIN错误:not exist domain in the zone
    域中不存在请求的记录,可能是CNAME对应的A记录不存在导致

  • REFUSED错误:
    拒绝客户端请求,可能是DNS策略导致

  • NOERROR不代表没有问题,也可以是过时的记录

  • 查看是否为权威记录,flags:aa标记判断

  • 被删除的记录仍能返回结果,可能是因为*记录存在
    *.example.com. A 172.25.254.254

  • 避免CNAME指向CNAME记录,可能产生回环
    test.example.com. CNAME lab.example.com.
    lab.example.com. CNAME test.example.com.

  • 正确配置PTR记录,许多服务依赖PTR,如sshd

相关文章

  • 20170921 DNS服务(二)

    bind view编译安装bindDNS排错 一、bind view (一)智能DNS 智能DNS:DNS服务器根...

  • OpenClash 无法访问内网的解决方案

    OpenClash ==> 全局设置 ==> DNS 设置 ==> 高级设置 ==> 指定第二 DNS 服务器 指...

  • DNS

    DNS服务 DNS域名 DNS域名结构 DNS解析 DNS服务器类型 区域传输 DNS解析 区域数据库 添加CNA...

  • 域名解析配置

    DNS层级结构 根DNS服务器:返回顶级域名DNS服务器的IP地址,*.cn 顶级域名DNS服务器:返回权威DNS...

  • docker搭建rabbitmq集群

    搭建DNS服务 为了方便rabbitmq服务之间能互链需要搭建DNS服务 创建dns docker容器,注意必须要...

  • 自建DNS管理子域名

    ref1 ubuntu DNS服务ref2 centos DNS服务ref3 DNS 服务详解 变量说明 INT_...

  • 服务器宝塔面板改DNS

    把服务器DNS改为 阿里DNS 主要DNS:223.5.5.5 备用DNS:223.6.6.6

  • 应用层(三)

    目录 2.5 DNS:因特网的目录服务 DNS提供的服务 DNS工作机理概述 DNS记录和报文 2.6 P2P应用...

  • 20170919 DNS服务(一)

    DNS简介DNS解析关键概念BIND 一、DNS简介: (一)DNS服务 DNS:Domain Name Serv...

  • 公共DNS服务器

    公共DNS服务器 云南运营商DNS服务器

网友评论

    本文标题:20170921 DNS服务(二)

    本文链接:https://www.haomeiwen.com/subject/kxmtextx.html