分布式、多活数据中心如何实现DNS域名解析和负载均衡?

阅读:358 2019-03-19 15:26:55 来源:csdn

关于双活技术和业界主流方案,应大家要求做了分析和分享(参考历史发文),为了帮助大家进一步理解,特意重要知识点做了梳理和细化,并整理成文。由于平时工作繁忙,只有利用周末时间写写文章,为了表示对我付出的认可,整理成文的“业界主流数据中心存储双活完全解析”需要收取一些费用,通过这种方式,也希望把自己的心血传递到真正需要的人手中,文章目录如下。

请需要的小伙伴通过原文链接获取。今天的话题将带你从双活数据访问层面,谈谈域名解析和负载均衡。

dns域名解析是b/s应用架构的一项重要服务,c/s架构应用一般是通过ip地址直接访问服务的。在云计算时代,业务主要通过b/s、分布式、多活的架构提供。然而对于网站运营和服务提供商来说,dns域名解析的稳定可靠,意味着更好的业务体验,更好更大的访问流量。

随着云计算和分布式系统的发展,dns在多数据中心、分布式应用架构中负载均衡和故障转移应用中越来越重要,今天我们对dns概念、应用和原理进行梳理和解析。

dns是互联网上作为域名和ip地址相互映射的一个分布式数据库。dns能够使用户更方便的访问网络和应用,而不用去记忆杂乱、繁琐的ip数串。通过域名,最终得到该域名对应的ip地址的过程叫做域名解析。下面这张图,详细说明了一个dns域名解析的全过程。

1、通常,在电脑打开浏览器,输入一个域名。比如输入www.163.com,这时电脑会发出一个dns请求到本地dns服务器。本地dns服务器一般是网络接入服务器商提供,比如中国电信,中国移动。

2、查询www.163.com的dns请求到达本地dns服务器之后,本地dns服务器会首先查询它的缓存记录,如果缓存中有此条记录,就可以直接返回结果。如果没有,本地dns服务器还要向dns根服务器进行查询。

3、根dns服务器没有记录具体的域名和ip地址的对应关系,而是告诉本地dns服务器,你可以到域服务器上去继续查询,并给出域服务器的地址。

4、本地dns服务器继续向域服务器发出请求,在这个例子中,请求的对象是.com域服务器。.com域服务器收到请求之后,也不会直接返回域名和ip地址的对应关系,而是告诉本地dns服务器,你的域名的解析服务器的地址。

5、最后,本地dns服务器向域名的解析服务器发出请求,这时就能收到一个域名和ip地址对应关系,本地dns服务器不仅要把ip地址返回给用户电脑,还要把这个对应关系保存在缓存中,以备下次别的用户查询时,可以直接返回结果,加快网络访问。

实际上,因特网上的dns服务器也是按照层次安排的。每一个域名服务器只对域名体系中的一部分进行管辖。根据域名服务器所起的作用,可以把域名服务器划分为根域名服务器、顶级域名服务器、权限域名服务器和本地域名服务器四种不同的类型。

根域名服务器是最高层次的域名服务器,也是最重要的域名服务器。所有的根域名服务器都知道所有的顶级域名服务器的域名和ip地址。不管是哪一个本地域名服务器,若要对因特网上任何一个域名进行解析,只要自己无法解析,就首先求助根域名服务器。所以根域名服务器是最重要的域名服务器。假定所有的根域名服务器都瘫痪了,那么整个dns系统就无法工作。

我们在配置dns解析的时候,需要指定dns解析的ttl(timetolive)参数,这个参数告诉本地dns服务器,域名缓存的最长时间。用阿里云解析来举例,阿里云解析默认的ttl是10分钟,10分钟的含义是本地dns服务器对于域名的缓存时间是10分钟,10分钟之后,本地dns服务器就会删除这条记录,删除之后,如果有用户访问这个域名,就要重复一遍上述复杂的流程。

如果网站已经进入稳定发展的状态,不会轻易更换ip地址,我们完全可以将ttl设置到协议最大值,即24小时。带来的好处是,让域名解析记录能够更长时间的存放在本地dns服务器中,以加快所有用户的访问。

分布式、多活数据中心对外提供数据服务时,还会涉及到另外一个参数rtt(roundtriptime)。分布在物理上a、b隔离两个区域的数据中心同时对外提供服务时,客户的服务请求是由a数据中心,还是由b数据中心响应,这就要看在dns解析过程中,决定于解析过程中那个访问带来的rtt更小。下面一起通过一个实例来分析下技术原理。

1、首先客户端向其所在运营商的localdns发起www.abc.com域名的dns请求。

2、运营商的localdns服务器从rootdns得知www.abc.com由dns-ctc、dns-cnc、dns-usa1和dns-usa2来解析,即rootdns同时返回此4个dns服务器地址给localdns(dns的工作原理要求返回所有关于请求的记录,在此即返回4个dns服务器,如果只返回一个dns而此dns刚好中断服务了,那么localdns只能是解析失败了);

3、localdns轮询向这4个dns服务器发出域名解析的请求,直到返回数据。

4、在此,假如dns-ctc响应localdns的域名解析请求,同时返回2台gtm的地址(本地监听的web服务)。

5、收到localdns请求的gtm首先查询在本地是否有该localdns的就近性表项,如果存在则直接给localdns返回速度最快的服务器地址。如果不存在,则通知另外一台gtm发起对该localdns的查询。

6、两台dns分别对localdns进行probe。例如gtm-a查询该localdns的rtt时间为50ms,而gtm-b查询同一localdns的rtt时间为100ms,则此时在两台gtm内都形成了该localdns的对应就近性表记录。

7、根据就近原则,localdns请求的gtm-a根据系统的就近性表返回相应的datacenter内的web服务器地址(即1.1.1.1)。

8、localdns获得地址后,将该地址返回给用户,到此dns请求过程结束。

9、用户向www.albc.com(1.1.1.1)网站发起访问。

分布式、多活数据中心中,一个域名对应两个业务ip地址,分别部署在两个数据中心。通过gslb或dns实现站点间的访问负载均衡。

gslb可以采用专用的f5gtm设备,如果业务量小,也可以采用windows自带的dns服务器,实现简单负载均衡(轮询),gslb跨站点负载均衡策略通常有两种。

1.基于localdns请求所在的地理位置。

2.基于gslb与localdns的rtt最小。

gslb在整个网络范围内将用户的请求定向到最近的节点(或者区域),主要采用就近性判断,主要的方法包括dns、应用层重定向、传输层重定向等。然而,slb大多在一个服务节点范围内,根据设备节点的健康性、当前负载、服务能力、分布等情况将用户的请求分配到一个具体服务节点设备。

整理成文的“业界主流数据中心存储双活完全解析”分析资料链接如下,请需要的小伙伴通过原文链接获取。

下一篇: 设置域名访问ftp
相关文章
{{ v.title }}
{{ v.description||(cleanHtml(v.content)).substr(0,100)+'···' }}
你可能感兴趣
推荐阅读 更多>
推荐商标

{{ v.name }}

{{ v.cls }}类

立即购买 联系客服