基于IP路由的GSLB《CDN技术详解》

基于IP路由的GSLB《CDN技术详解》基于IP路由的GSLB是基于路由器原有的路由算法和数据包转发能力工作的。如图所示,有两个本地均衡器1和2,放在不同的POP点中,负责各自POP点内的服务器的负载均衡。先为这两个本地均衡器配置一个相同的VIP地址,对IP网上的路由器来说,这是到同一个IP地址的两条不同的路由。1)当终端a输入URL访问网站时,DNS系统会把VIP作为域名解析结果反馈给终端。2)终端向这个VIP发送请求时,请求数…

大家好,又见面了,我是你们的朋友全栈君。

基于IP路由的GSLB是基于路由器原有的路由算法和数据包转发能力工作的。

如图所示,有两个本地均衡器1和2,放在不同的POP点中,负责各自POP点内的服务器的负载均衡。先为这两个本地均衡器配置一个相同的VIP地址,对IP网上的路由器来说,这是到同一个IP地址的两条不同的路由。
1)当终端a输入URL访问网站时,DNS系统会把VIP作为域名解析结果反馈给终端。
2)终端向这个VIP发送请求时,请求数据包经过路由器A,路由器A查看路由表来决定通过哪条路径转发数据包至VIP。它会发现有两条不同的路由,然后基于路由协议算法选择一条路由到达这两个本地均衡器中的一个。
因为每次访问请求的终端IP地址不同,路由条件也不同,所以在多个路由器上优选的路由不同,从统计复用的角度来看基本是在负载均衡器1和2之间均匀分布的。这样,就通过路由器实现了两个POP点之间的负载均衡。
在这里插入图片描述

上面讲述的这种基于IP路由的GSLB方案主要艘建议用于使用IGP协议(内部网关协议)的一个城域网或者自治城内部,很难实现基于BGP协议(外部网关协议)的畴自治域全国性负载均衡。
因为在默认情况下,大多数BGP协议的路由器都不维护单台主机的路由,否则会导致路由表过于庞大。运营商为了控制路由条目的数量,也会丢弃主机路由。但是为了让基于IP路由的GSLB能正常工作,每台路由器都必须维护一条到VIP的主机路由。这样,就要求选用这种GSLB方案的CDN服务商与运营商相协调路由器针对某个VIP的主机路由可用,这种协商很可能不被运营商接受,这也是本方案实施的局限性。

2006年Cisco公司叉提出一种LISP协议(Locator/ID Separation Protocol),用于多数据中心选址。它的核心思想是对数据包进行IP嵌套,实现访问同一IP地址(内层IP)的请求被路由到不同目的IP(外层IP)去。

在这里插入图片描述
简单的LISP的工作原理,如图所示。
LISP工作原理

图中的ITR和ETR是两台边缘设备MR与MS协同完成管理任务。

用户发往目的主机的数据报文第一次到达客户区域的LISP边缘设备ITR时,ITR会根据报文的目的IP地址向MR请求查询对应的ETR的公网IP(Locator IP),而这个IP地址的获得是通过MR与MS、ETR的通信获得的。获得LoCator IP以后,ITR会把它封装在数据报文的外层报头中,再将数据报文发到公网上。数据报文到达ETR时,ETR会剥去外屡报头,再根据内层报头的IP和端口信息进行转发。这样,即使多个用户访问的是同一个目的IP,也可能因为外层封装中的LocaLorIP不同而被调度到不同的POP点去。

LISP中各角色之间的关系人都是通过手工指定的方式建立的,如ITR上需要指定MR地址,ETR上需要指定MS地址,ETR发布哪些内部IP信息到MS上,都是手工指定的。只有MR和MS之间可以通过BOP来建立邻接关系。LISP有两个优点,一是公网设备不需要学习站点内部明细IP路由项,二是当访问的目标服务在站点间迁移时,可以只变更Locator IP,而不需要对真正的目的IP进行变更。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/143013.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • ‘utf-8’ codec can’t decode byte 0xff in position 0: invalid start byte[通俗易懂]

    ‘utf-8’ codec can’t decode byte 0xff in position 0: invalid start byte[通俗易懂]‘utf-8’codeccan’tdecodebyte0xffinposition0:invalidstartbyte觉得有用的话,欢迎一起讨论相互学习~FollowMe今天使用语句image_raw_data_jpg=tf.gfile.FastGFile(‘../test_images/test_1.jpg’,’r’).read()读取图片文件的时候遇到了以下问题:’

    2022年6月16日
    326
  • 写给大忙人看的操作系统

    文章主要结构图如下操作系统现代计算机系统由一个或多个处理器、主存、打印机、键盘、鼠标、显示器、网络接口以及各种输入/输出设备构成。然而,程序员不会直接和这些硬件打交道,而且每位程序员不可能会掌握所有计算机系统的细节,这样我们就不用再编写代码了,所以在硬件的基础之上,计算机安装了一层软件,这层软件能够通过响应用户输入的指令达到控制硬件的效果,从而满足用户需求,这种软件称之为操作系统,它的…

    2022年4月13日
    37
  • 10个最好的 JavaScript 动画库【值得收藏】

    10个最好的 JavaScript 动画库【值得收藏】前端动画场景需求多众多,面对这么多花里胡哨的动画需求,这里给大家推荐10个比较好用的js动画库,轻松实现各种花里胡哨的动画❤️1.Tween.jsTweenJS是一个简单的JavaS…

    2022年10月15日
    0
  • vue组件引入layui框架的table组件「建议收藏」

    vue组件引入layui框架的table组件「建议收藏」注:暂时解决了问题,以后再根据情况更新。layui框架中,layer、laydate、layim可以作为单独的模块来使用,所以可以在vue组件中直接使用,但是对于layui的其它组件,如数据表格table组件,则不能直接使用。可以通过在入口js文件加入以下代码,解决:require"**/layui.js"//**代表layui所在的路径…

    2022年6月25日
    58
  • RestSharp_restbed

    RestSharp_restbedRestSharp介绍RestSharp是一个.NET平台下REST和HTTPAPI的开源客户端库,支持的平台包括.NET3.5/4、Mono、MonoforAndroid、MonoTouch、WindowsPhone7.1Mango、WindowsPhone8.1。RestSharp可以简化用户访问Restful的服务过程,在这里下载代码可以让用户更简单的使用RestSha…

    2022年9月8日
    0
  • anyMatch_any后面加什么

    anyMatch_any后面加什么importcom.it.vo.Student;importjava.util.ArrayList;importjava.util.List;/***anyMatch(Predicatep)传入一个断言型函数,对流中所有的元素进行判断,*只要有一个满足条件就返回true,都不满足返回false。*/publicclassTest{publicstaticvoidmain(String[]args){Studentstu1.

    2022年4月19日
    33

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号