What is GSLB
Global Server Load Balancing
中文:全局负载均衡
SLB(Server load balancing)是对集群内物理主机的负载均衡,而GSLB是对物理集群的负载均衡。
这里的负载均衡可能不只是简单的流量均匀分配,而是会根据策略的不同实现不同场景的应用交付。
GSLB是依赖于用户和实际部署环境的互联网资源分发技术,不同的目的对应着一系列不同的技术实现。
Why GSLB
总结为:
- 高可用性
- 更快的响应时间
- 多版本分发
具体:
- Disater recovery,发生故障时提供一个备用的位置来获取资源或者能提供可简易调整流量的装置,或两者都能提供。
- Load sharing,基于多个地理位置的流量分发,可以做到: - a.尽量节省带宽 
 b.限制给定位置的能力
 c.限制暴露断电,地理灾害等问题
- Performance,将资源置于离用户更近的地方,增强用户体验。 
- 多版本,根据本地政策提供不同版本的资源,或者根据自定义的规则提供为特殊用户提供特殊版本,如灰度交付等。
How implements GSLB
主流的技术实现
DNS
GSLB会替代最终的DNS的服务器从而实现自己的解析策略,返回给用户最合适的IP(列表)。

一个普通的DNS请求:
| 1 | ① 用户提交域名 | 
加入了GSLB的请求:
| 1 | ① 提交域名 | 
特点:
- 这个技术对原业务的侵入性最小,被商业ADC广泛实现,如A10,F5等。 
- 但是可以得到的信息很有限,IP的定位只能靠Local DNS,因为得不到源IP. 
 
HTTP redirection
使用HTTP重定向将内容转发到不同位置.
a. 请求的域名均解析为GSLB机器的IP.
b. GSLB根据源IP等信息解析出新的IP并使用HTTP重定向技术将用户请求重定向到目标主机.

请求过程:
| 1 | ① 提交域名 | 
特点:
- 这个方案只适用于HTTP. 
- 这个方案的实现可以是L7负载均衡工具如Nginx、HTTPD等 
 
IP Route
更改IP首部实现使用跳转.并利用IP tunneling技术实现只对请求负载均衡(响应直接返回).
a. 请求的域名均解析为GSLB机器的IP.
b. 负载均衡设备可以解析出目标地址,然后封装IP包发给目标地址.
c. 目标服务器收到请求包并处理,解析出被封装的IP包可以得到客户端地址,把响应直接返回.

请求过程:
| 1 | ① 提交域名 | 
特点
- 这个方案能解决不能获得源IP和HTTP Only的问题,也不会成为性能瓶颈.但由于是IP层的LB,因此得到的信息很有限,也就是做分发的策略会很有限.*
 
- 实现方式主要就是LVS的VS/TUN模式.如果自己编写会更灵活,但难度较大.*
 
- 实现方式主要就是LVS的
统一调度服务层
客户端SDK+调度服务完成GSLB设备的功能。
a. 客户端使用原地址请求服务时,SDK会交付一个解析过的地址给客户端.(或对网络请求模块做Proxy)
b. SDK会通过一定的策略从调度服务中获取解析地址(一个或多个).
c. SDK和调度服务会某种形式保持联系(HTTP or TCP).
d. 出于性能考虑,SDK本身有Cache功能同时有时效限制(TTL)。

调用试请求过程:
① 客户端请求
② 调用SDK
③ SDK没有命中缓存
 ④ SDK请求调度服务
 ⑤ 调度服务返回新地址
 ⑥ 客户端用新地址发起请求
代理式请求过程:
① 客户端发起请求
② 网络请求Proxy拦截请求
③ Proxy没有命中缓存
④ Proxy请求调度服务
⑤ 调度服务返回新地址
⑥ Proxy请求新地址
特点
- 让客户端(SDK)具备了负载均衡知识,而因此让服务端可以获得任何想要知道的信息,从而可以做更全面的解析策略,但侵入性是最大的。
 
常见策略实现
- 地理区域。地理&IP表。
- IP权重,为每个IP分配权重,权重决定流量比例。
- 往返时间RTT,分active RTT(请求时ping)和passive RTT(采集tcp的syn->act的时间)。
- 业务自定义条件,如根据语言,UserID等.
 
方案的对比
方案1:
工具:使用现有的商用解决方案:F5,A10 Thunder.
优点:
  能灵活配置GSLB,满足就近选择,位置备份等基本GSLB需求。
  除了GSLB以外,还能带来对性能和安全的全解决方案,如防DDos,硬件加速SSL加解密等等。
  当我们的业务群越来越庞大时,这些需求会越来越迫切。
缺点:
  贵。
方案2
工具:编写HTTP转发服务或使用Nginx,HTTPD
优点:自由实现,HTTP层可获取的信息更多因此LB策略更灵活.
缺点:只能是HTTP的转发,另外可能会成为性能瓶颈.
方案3
工具:使用LVS的VS/TUN模式
优点:free
缺点: 能实现的LB策略只能是LVS所支持的那些,如果想自己定义似乎不可能。
方案4
工具:编写统一调度服务
优点:有HTTP转发的所有优点,而且不需要流量经过,因此性能要比HTTP转发高很多。
缺点:
  1. 需要客户端的参与。(基本排除了浏览器和升级困难)。稍显复杂的缓存策略。
  2. 这个服务会成为一个`移动接入层`,将会具备相当规模。(成本)。
总结
选择方案首先选择能完全满足自己业务需求的方案.然后在从中选择功能&性能/价格比最高的.
以上四个方案,也可以分为L7层和其他.对于需要更多业务信息参与的负载均衡,则必须从7层协议入手.
方案2和方案4都可以解析7层协议的内容,其中方案4则能更灵活的实现通用的负载均衡,条件是必须有客户端的支持.因此如果能解决客户端的问题则方案4是比较好的方案,否则只能选择方案2了.
另外也不一定选择一种方案,能有效结合这些方案会使负载均衡能力更强大.
比如方案4无法干预浏览器的请求,这个时候就需要使用其他方案来弥补(方案1,2,3皆可).
同时还要区分动态资源和静态资源的请求,以上方案主要使针对动态资源的负载均衡,对于静态资源,CDN提供了更好的解决方案.
参考资料:
Citrix的NetScaler说明书: http://support.citrix.com/servlet/KbServlet/download/22506-102-671576/gslb-primer_FINAL_1019.pdf
GSLB和CND: http://blog.csdn.net/u010340143/article/details/9062213
智能DNS: http://www.cnblogs.com/peon/archive/2007/12/30/1021219.html
负载均衡: http://blog.arganzheng.me/posts/load-balance.html
LVS: http://www.linuxvirtualserver.org/zh/lvs1.html
What is GSLB的更多相关文章
- CDN 技术详解(DNS,GSLB,Cache)
		CDN 是什么 CDN(Content Delivery Network,内容分发网络),即全网内容加速服务.为了尽可能的避开互联网上有可能影响数据传输速度和稳定性的瓶颈和环节,使内容传输的更快.更稳 ... 
- 全局负载均衡GSLB之“部署篇”
		http://virtualadc.blog.51cto.com/3027116/875622 前言 随着web应用的不断发展,客户对于业务的稳定性.可靠性等也提出更高的要求,已不再局限于IDC内部的 ... 
- DNS全局负载均衡(GSLB)基本原理
		原理 DNS全局负载均衡通过智能DNS解析来实现,通常在不同的地区设立多个数据中心,每个数据中心又使用多个运营商的线路.目前很多DNS服务商都提供了智能DNS服务,智能DNS通常是利用各运营商分省IP ... 
- 转发 GSLB概要和实现原理
		What is GSLB Global Server Load Balancing 中文:全局负载均衡 SLB(Server load balancing)是对集群内物理主机的负载均衡,而GSLB是对 ... 
- Netscaler GSLB的主备数据中心解决方案
		Netscaler GSLB的主备数据中心解决方案 http://blog.51cto.com/caojin/1898182 GSLB的主.备数据中心解决方案思路: 其实这只是多数据中心的一个特例而已 ... 
- Why DNS Based Global Server Load Balancing (GSLB) Doesn’t Work
		Why DNS Based Global Server Load Balancing (GSLB) Doesn't Work 
- 多IDC GSLB的部署 - ADC技术博客 - 51CTO技术博客
		多IDC GSLB的部署 - ADC技术博客 - 51CTO技术博客 A10 
- CDN技术之--全局负载均衡(GSLB)
		负载均衡就是智能调度全局负载均衡(GSLB)的负载均衡主要是在多个节点之间进行均衡,其结果可能直接终结负载均衡过程,也可能将用户访问交付下一层次的(区域或本地)负载均衡系统进行处理.GSLB最通用的是 ... 
- gslb(global server load balance)技术的一点理解
		gslb(global server load balance)技术的一点理解 前言 对于比较大的互联网公司来说,用户可能遍及海内外,此时,为了提升用户体验,公司一般会在离用户较近的地方建立机房,来服 ... 
随机推荐
- css3 @font-face
			很长时间,web设计师总是得用一些“web-safe”字体,英文用body{font-family:"corbel", Arial, Sans-serif; }中文用body{f ... 
- SVN服务器&客户端的搭建和使用
			目录结构: 1. SVN服务器搭建和使用-VisualSVNServer 2. SVN客户端安装和使用-TortoiseSVN 3. TortoiseSVN使用方法 SVN简介 SVN是Subvers ... 
- TopCoder SRM 639 Div.2 500  AliceGameEasy --乱搞
			题意: 一个游戏有n轮,有A和B比赛,谁在第 i 轮得胜,就获得 i 分,给出x,y,问A得x分,B得y分有没有可能,如果有,输出A最少赢的盘数. 解法: 这题是我傻逼了,处理上各种不优越,要使n*( ... 
- AC日记——潜伏着 openjudge 1.7 11
			11:潜伏者 总时间限制: 1000ms 内存限制: 65536kB 描述 R国和S国正陷入战火之中,双方都互派间谍,潜入对方内部,伺机行动. 历经艰险后,潜伏于S国的R国间谍小C终于摸清了S国军 ... 
- linux下安装python
			在Linux下安装Python的操作相当简单,按如下步骤操作即可: 命令: wget https://www.python.org/ftp/python/3.5.2/Python-3.5.2.tgzt ... 
- [No000016]为什么假期计划总是做不到?
- JS原型与原型链终极详解
			一. 普通对象与函数对象 JavaScript 中,万物皆对象!但对象也是有区别的.分为普通对象和函数对象,Object ,Function 是JS自带的函数对象.下面举例说明 function f ... 
- JavaScript 各种页面跳转方法
			第一种: window.location.href="login.jsp?backurl=\"+window.location.href; 第二种: alert("返回& ... 
- sublime安装package control组件
			第一步,首先到这个网站https://packagecontrol.io/installation去下载Package Control.sublime-package文件 第二步,将下载的文件放到C: ... 
- 运维利器-ClusterShell集群管理操作记录
			在运维实战中,如果有若干台数据库服务器,想对这些服务器进行同等动作,比如查看它们当前的即时负载情况,查看它们的主机名,分发文件等等,这个时候该怎么办?一个个登陆服务器去操作,太傻帽了!写个shell去 ... 
