DNS(7) -- 智能DNS实现
1. 智能DNS
1.1 智能DNS概述
智能DNS就是根据用户的来源地域,自动智能化判断来路IP返回给用户,而不需要用户进行选择。
智能DNS实现的主要功能:
- 可以根据用户来路和运营商智能判断最优访问线路;
- 服务器故障自动替换宕机节点,保障最优访问线路;
- 负载均衡:对于流量比较大的网站,可以把流量分配到几台不同的服务器上,以提高网站速度;
比方一个企业的站点三个运营商的带宽都有:电信、联通、移动;同样来自三个不同 运营商网络的访问用户,假设电信用户访问企业网址的时候,智能DNS会自动根据IP判断,再从电信返回给电信用户,其他的也同理;
电信用户:访问 www.sina.com 返回 1.1.1.1;
联通用户:访问 www.sina.com 返回 2.2.2.2;
移动用户:访问 www.sina.com 返回 3.3.3.3;
1.2 ACL控制列表
acl:访问控制列表;把一个或多个地址归并一个命名的集合,随后通过此名称即可对此集全内的所有主机实现统一调用;
bind内置了四个四种ACL
any :允许所有主机节点查询;
none :拒绝所有主机节点查询;
localhost :仅允许本地接口网络主机查询;
localnet :本地子网所有IP;
也可以自定义ACL规则,示例如下:
#1.复杂acl规则定义
acl "ips" { <==定义一个名为ips的ACL
10.0.0.1; 10.0.0.2; 192.168.1.1; <==包含3个单个IP
172.16.1.0/24;
...
}; #2.复杂acl规则定义
acl "all_rule" { <==定义一个名为all_rule的ACL
"ips"; <==可以嵌套包含其他ACL
10.0.15.0/24; <==包含10.0.15.0子网中的所有IP
!10.0.16.1/24; <==非10.0.16.1子网的IP
{10.0.17.1;10.0.18.2;}; <==包含了一个IP组
localhost; <==本地网络接口IP(含实际接口IP和127.0.0.1)
};
1.3 智能DNS实现
1.3.1 bind-view功能
view 语句定义了视图功能,视图是BIND9提供的强大的新功能,允许DNS服务器根据不同的客户端,请求相同的域名,但返回不同的解析结果。
view的语法格式为:
view view_name [class] { <==view为声明关键字 ,后面加上自定义的view名称
match-clients { address_match_list } ; <==匹配的客户端ACL
match-destinations { address_match_list } ; <==匹配访问的目标地址的ACL;
match-recursive-only { yes_or_no } ;
[ view_option; ...]
};
view的功能的主要事项如下:
- 一个bind服务器可定义多个view,每个view中可定义一个或多个zone;
- 每个view用来匹配一组客户端;
- 多个view内可能需要对同一个区域进行解析,但使用不同的区域解析库文件;
- 一旦启用了view,所有的zone都只能定义在view中,否则会失效;
- 仅在允许递归请求的客户端所在view中定义根区域;
- 客户端请求到达时,是自上而下检查每个view所服务的客户端列表;
1.3.2 智能DNS场景实现
目标:
- 客户端192.168.20.17请求域名eip.xuzhichao.com是解析到地址100.1.1.1;
- 客户端192.168.20.30请求域名eip.xuzhichao.com是解析到地址100.2.2.2;
bind的配置文件如下:
[root@dns01 named]# cat /etc/named.conf
options {
listen-on port 53 { localhost; };
listen-on-v6 port 53 { localhost; };
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";
recursing-file "/var/named/data/named.recursing";
secroots-file "/var/named/data/named.secroots";
allow-query { any; }; recursion yes;
allow-recursion { 192.168.20.0/24; 192.168.50.0/24; }; allow-transfer {192.168.20.71;};
also-notify {192.168.20.71;}; dnssec-enable yes;
dnssec-validation yes; bindkeys-file "/etc/named.root.key"; managed-keys-directory "/var/named/dynamic"; pid-file "/run/named/named.pid";
session-keyfile "/run/named/session.key";
}; logging {
channel default_debug {
file "data/named.run";
severity dynamic;
};
}; acl "test-env" { <==定义ACL
192.168.20.17;
}; acl "shengchan-env" {
192.168.20.30;
}; view "test-env-view" { <==定义view
match-clients { "test-env"; }; <==匹配客户端地址
zone "xuzhichao.com" IN { <==在view下定义区域配置文件
type master;
file "xuzhichao.com.test.zone";
};
}; view "shengchan-env-view" {
match-clients { "shengchan-env"; };
zone "xuzhichao.com" IN {
type master;
file "xuzhichao.com.shengchan.zone";
};
}; view "default" {
zone "." IN {
type hint;
file "named.ca";
}; include "/etc/named.rfc1912.zones";
include "/etc/named.xuzhichao.com.zone";
}; include "/etc/named.root.key";
区域解析文件如下:
[root@dns01 named]# cat /var/named/xuzhichao.com.shengchan.zone
$TTL 86400 xuzhichao.com. IN SOA ns1.xuzhichao.com. mail.xuzhichao.com. (
2021071603
10800
900
604800
86400
) xuzhichao.com. IN NS ns1.xuzhichao.com.
xuzhichao.com. IN NS ns2.xuzhichao.com. ns1 IN A 192.168.20.70
ns2 IN A 192.168.20.71 xuzhichao.com. IN MX 10 mx1.xuzhichao.com.
mx1 IN A 192.168.20.11 eip.xuzhichao.com. IN A 100.2.2.2 [root@dns01 named]# cat /var/named/xuzhichao.com.test.zone
$TTL 86400 xuzhichao.com. IN SOA ns1.xuzhichao.com. mail.xuzhichao.com. (
2021071603
10800
900
604800
86400
) xuzhichao.com. IN NS ns1.xuzhichao.com.
xuzhichao.com. IN NS ns2.xuzhichao.com. ns1 IN A 192.168.20.70
ns2 IN A 192.168.20.71 xuzhichao.com. IN MX 10 mx1.xuzhichao.com.
mx1 IN A 192.168.20.11 eip.xuzhichao.com. IN A 100.1.1.1 #修改属组和权限:
[root@dns01 named]# chgrp named /var/named/xuzhichao.com.test.zone
[root@dns01 named]# chmod 640 /var/named/xuzhichao.com.test.zone
[root@dns01 named]# chgrp named /var/named/xuzhichao.com.shengchan.zone
[root@dns01 named]# chmod 640 /var/named/xuzhichao.com.shengchan.zone
检测语法,重启bind服务:
[root@dns01 named]# named-checkconf
[root@dns01 named]# named-checkzone xuzhichao.com /var/named/xuzhichao.com.test.zone
zone xuzhichao.com/IN: loaded serial 2021071603
OK
[root@dns01 named]# named-checkzone xuzhichao.com /var/named/xuzhichao.com.shengchan.zone
zone xuzhichao.com/IN: loaded serial 2021071603
OK
使用客户端测试效果:
#1.使用192.168.20.17的客户端进行测试:
[root@xuzhichao ~]# dig eip.xuzhichao.com @192.168.20.70 +short
100.1.1.1 #2.使用192.168.20.30的客户端进行测试:
[root@dns-son ~]# dig eip.xuzhichao.com @192.168.20.70 +short
100.2.2.2
1.3.3 生产场景配置示例
根据不同的运营商地址返回不同的DNS解析结果:
//电信IP访问控制列表
acl "telecomip"{
telecom_IP;
...
};
//联通IP访问控制列表
acl "netcomip"{
netcom_IP;
...
};
view "telecom" {
match-clients { "telecomip"; };
zone "ZONE_NAME" IN {
type master;
file "ZONE_NAME.telecom.zone";
};
};
view "netcom" {
match-clients { "netcomip"; };
zone "ZONE_NAME" IN {
type master;
file "ZONE_NAME.netcom.zone";
};
};
view "default" {
match-clients { any; };
zone "ZONE_NAME" IN {
type master;
file "ZONE_NAME.zone";
};
};
DNS(7) -- 智能DNS实现的更多相关文章
- 智能DNS
DNS查找下一个服务的地址 一.智能DNS APP通过域名访问DNS服务器,DNS根据域名对应一组IP中随机选择一个,发给APP.从这个意义说智能DNS,智能DNS相当一个七层的负载均衡. 二.H ...
- DNS中的AC、rndc、智能DNS解析和基础排错
bind中的ACL和rndc DNS除了服务器外,还具有一些访问控制和视图功能. 访问控制是指仅对定义的网络进行解析,视图也就是智能解析. 1>访问控制是通过acl函数来实现的,acl把一个或多 ...
- DNS原理和智能DNS及CDN
CDN是什么 CDN(Content Delivery Network)是内容分发网络. 作用: 使用户可以就近取的所需要的内容,加速用户访问网站资源的速度.物理距离更近,响应速度更快.拦截部分网络请 ...
- C#实现DNS解析服务和智能DNS服务
C#实现DNS解析服务有一个开源项目ARSoft.Tools.Net, ARSoft.Tools.Net是一个非常强大的开源DNS控件库,包含.Net SPF validation, SenderID ...
- 烂泥:智能DNS使用与配置
本文由ilanniweb提供友情赞助,首发于烂泥行天下 想要获得更多的文章,可以关注我的微信ilanniweb 公司的业务现在已经扩展到海外,对外提供的统一接口都是通过域名来解析的,但是海外用户访问国 ...
- 简单介绍智能DNS解析+双线路接入
导读:在讨论这个问题,其中群友老孤同志也提供了不少非常有参考价值的资料,所以我们再把这些资料再整理一次,从比较底层的技术原理上重新进行一次分析. 我们知道,因为南电信北网通现象的存在,我们的服务器 ...
- 才知道百度也提供了智能DNS服务 - 加速乐
http://jiasule.baidu.com/ 智能DNS 依托百度多年积累的高精度DNS识别库,平均只需5秒全球DNS服务器全部生效,百度蜘蛛1秒生效.抗攻击.无限解析记录,免费支持电信.联通. ...
- 什么是智能dns解析
智能DNS解析是针对目前电信和网通互联互通不畅的问题推出的一种DNS解决方案.具体实现是:把同样的域名如test.winiis.com的A记录分别设置指向网通和电信IP,当网通的客户访问时,智能DNS ...
- DNS加速之“智能DNS”跟“双线加速”、“CDN加速”的区别
“智能DNS”跟“双线加速”.“CDN加速”的区别相信,很大部分IDC用户可能还没弄清楚状况,有人觉得智能DNS跟双线加速.CDN加速是类似的技术.其实不然,它们在工作方式上有着本质的区别,但它们又可 ...
- DNS—正、反向解析;委派;主从;子域;转发;智能dns等的实现
前言:DNS,耳熟能详的东西,内容太多,小编也不太好讲清,只能写几个实验详解,供大家参考. 一.简单介绍 1.DNS:通过主机名,最终得到该主机名对应的IP地址的过程叫做域名解析(或主机名解析). 端 ...
随机推荐
- #FFT#P4173 残缺的字符串
题目 有一个长度为 \(m\) 的字符串 \(A\) 和 一个长度为 \(n\) 的字符串 \(B\), 它们有若干位置为通配符,现在问 \(B\) 的每一个后缀是否存在前缀为 \(A\). 分析 考 ...
- #分块,可撤销并查集#洛谷 5443 [APIO2019]桥梁
题目 分析 最直接的做法就是在线一边修改边权,询问直接全部重排, 然后用可撤销并查集维护连通块大小,这样时间复杂度为 \(O(qm)\) 同样尽量让大部分的边不需要修改边权,那么每 \(B\) 个操作 ...
- #Tarjan#洛谷 4819 [中山市选]杀人游戏
题目 分析 缩点后显然只考虑入度为0的点的个数, 但是问题是如果有一个入度为0的点缩点前只有1个点 且它的出边上的所有点都可以被其它入度为0的点遍历, 那么可以将其它点全部排除后剩下的这个点就是凶手, ...
- 劫持TLS绕过canary pwn89
劫持TLS绕过canary pwn88 首先了解一下这个东西的前提条件和原理 前提: 溢出字节够大,通常至少一个page(4K) 创建一个线程,在线程内栈溢出 原理: 在开启canary的情况下,当程 ...
- std::thread 三:条件变量(condition_variable())
condition_variable . wait . notify_one . notify_all *:notify_one:通知(唤醒)一个线程 *:notify_all:通知( ...
- 大型场景中通过监督视图贡献加权进行多视图人物检测 Multi-View People Detection in Large Scenes via Supervised View-Wise Contribution Weighting
Multi-View People Detection in Large Scenes via Supervised View-Wise Contribution Weighting 大型场景中通过监 ...
- Centos 8.0 minimal命令行安装图形化界面(超详细)
Centos 8.0 安装图形化界面(超详细) 开始之前呢,请先查看您的Centos版本和是否有root账户权限. 一.安装Centos 图形化界面并重启 下载安装图形化界面 执行命令 yum gro ...
- Spring Cloud OpenFeign:基于Ribbon和Hystrix的声明式服务调用
Spring Cloud OpenFeign:基于Ribbon和Hystrix的声明式服务调用 SpringCloud学习教程 SpringCloud Spring Cloud OpenFeign 是 ...
- 行业软件开发商怎样来抢 BI 这块蛋糕?
随着企业信息化建设的深入,很多机构的生产系统已建设完成,在保证生产的有序进行后,如何更有效地进行经营决策成了管理者面临的最大任务.商业智能(BI)就是在这种背景成为支撑企业经营分析的一大利器. 根据 ...
- nginx重新整理——————分析log数据[六]
前言 简单介绍一下goaccess. 正文 安装: yum install epel-release yum install GeoIP GeoIP-devel GeoIP-data yum inst ...