20170921 DNS服务(二)

  • 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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,937评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,503评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,712评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,668评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,677评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,601评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,975评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,637评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,881评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,621评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,710评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,387评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,971评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,947评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,189评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,805评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,449评论 2 342

推荐阅读更多精彩内容

  • 1. 概述 在网络环境中一般用户只需要在浏览器中输入url如www.sunny.com就可以到对应服务器获取相应的...
    ghbsunny阅读 2,865评论 0 7
  • DNS简介DNS解析关键概念BIND 一、DNS简介: (一)DNS服务 DNS:Domain Name Serv...
    哈喽别样阅读 1,781评论 0 2
  • 一、实现从根,com,rj.com 模拟互联网的DNS架构 DNS(Domain Name System,域名系统...
    ssjinyao阅读 1,412评论 0 7
  • 什么是DNS及功能: DNS(Domain name server),是将IP地址转换为域名地址。当在互联网访问外...
    魏镇坪阅读 7,626评论 0 8
  • 今天在家看了《喊山》这部电影,其中最让我动容的一个情节就是韩冲在经历了与全村阻挠他去自首的人的搏斗后,看着带着老村...
    林一支阅读 574评论 0 0