基于BIND实现智能DNS解析
智能DNS又称为解析切割,是对请求DNS解析的IP地址进行判断,将域名解析成不同的地址
一般智能DNS应用常见的场景就是CDN,中国特色社会主义的网络导致了电信和联通这2个特色的运营商,而这2个运营商通过在北京某机房的100G带宽相连,这就导致了电信用户访问联通的网络就会非常慢。玩游戏的童鞋就知道用游戏加速器来解决问题,但一般的用户访问在不同运营商网络的服务器时,变得非常慢。于是苦逼的服务提供商为了更好的用户体验就不得不去花费一笔钱去买CDN服务了。。。。
CDN的原理就是在智能DNS基础上进行web的反向代理缓存实现的。通过不同地域的请求解析到对应地域的缓存服务器上,然后缓存服务器对主服务器进行数据请求,最终返回给客户。这对于静态页面的网站有着很好的加速。
这里就不得不提一下著名的提供智能DNS解析服务的DNSpod(目前已被腾讯收购,软件源代码已经开源,宣称非BIND可以比拟,有兴趣的童鞋可以去研究研究)。还有比较著名的CDN服务提供商有帝盟等。。。
还会一种会使用到智能DNS的场景:在公司内部NS服务器上区分内部和外部的请求,将内部请求解析到内网地址上,外网请求解析到外网地址上,此篇博文针对此应用展开
BIND实现智能DNS的原理是通过view的方式,首先判断客户请求的来源,然后返回不同的IP
规划:为lustlost.com域进行智能解析
分2个网段,192.168.92.0/24网段的请求解析到192.168.92.102主机上, 其它网段解析到172.19.19.102主机
这里172.19.19.102模拟外网。
这和一般公司的模式很接近,为公司内部提供内部私网地址的解析,避免路由器性能浪费。为外部提供公网地址的解析。
ns服务器的IP地址为192.168.92.102和172.19.19.102
[root@lustlost ~]# yum install bind caching-nameserver –y #安装bind和caching-nameserver,这里的caching-nameserver已经给我们在相应目录下提供了配置文件,根区域和本地区域的数据文件,而且它的主配置是默认以view方式配置的
[root@lustlost etc]# cp /etc/named.caching-nameserver.conf named.conf #用cp备份原配置文件,建立要使用的配置文件,然后进行修改
[root@lustlost etc]# vim /etc/named.conf
- #首先定义控制列表,这里定义了内网的网段
- acl innet {
- 127.0.0.0/8;
- 192.168.92.0/24;
- };
- #全局配置,精简一点,只配置数据文件目录位置
- options {
- directory "/var/named";
- };
- #创建内网用户的view
- view in {
- match-clients { innet; }; #定义用户为控制列表中所定义的
- recursion yes; #允许内网用户进行递归查询
- #下面是定义根区域和本地区域的正反解析
- zone "." IN {
- type hint;
- file "named.ca";
- }
- zone "localhost" IN {
- type master;
- file "localhost.zone";
- }
- zone "0.0.127.in-addr.arpa" IN {
- type master;
- file "named.local";
- }
- #定义内部网络用户解析
- zone "lustlost.com" IN {
- type master;
- file "lustlost.com.in";
- allow-transfer { none; }; #不允许区域传送
- allow-update { none; }; #不允许更新
- }
- };
- #定义外部网络用户解析
- view out {
- match-clients { any; }; #允许所有用户(这里之所以允许所有用户,
- 是因为bind对配置文件是从上往下读取解析的,
- 匹配不到上面view所定义的acl,
- 才会到这个view中来)
- recursion no; #不允许外部网络用户进行递归查询(我们不是免费的公共dns)
- zone "lustlost.com" IN {
- type master;
- file "lustlost.com.out";
- allow-transfer { none; };
- allow-update { none; };
- }
- };