- 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