一篇文章把负载均衡的高可用性给大家讲明白!
haoteby 2025-03-17 18:16 31 浏览
高可用性
负载均衡器本身的一个重要作用就是提供高可用性。
另外,其本身也需要是一个高可用的系统。
3.2.1 使用Keepalived做健康检查
Keepalived是一常常用来配合四层负载均衡器使用的软件。除了可以管理负载均衡配置,它还有很多其他功能。健康检查就是一项不可忽视的功能。
Keepalived的健康检查可以工作在网络层、传输层或应用层。即它可以发送ICMP探测包、TCP/UDP健康检查报文包、HTTP请求来进行健康检查。当发现返回的数据不是自己期望的值时,就会判断后端服务器已经不再健康,需要从集群中摘除。
以常用的TCP的负载均衡来说,使用TCP_CHECK进行健康检查。健康检查的方法是由负载均衡器发送SYN包到后台指定的端口(一般是设置为后台服务器提供服务的端口),当后台服务器返回SYN/ACK后,负载均衡器就认为后台服务还是健康的,会向后台服务器发送一个RST数据包,同时关闭自己的TCP连接。这样非完整状态的三次握手、四次挥手可以较快地进行健康检查,也利于节约资源。TCP-CHECK的一般会在real_server的配置块内部进行配置,代码如下:
另外,如果四层负载均衡实际上提供的是HTTP的服务,则可以使用HTTP_GET进行健康检查。它主要是根据发送HTTP请求获得的响应,并进行md5加密,查看与期望值是否相符。如果与期望值相符,则认为后端服务器是健康的,否则摘除这个后端服务器。HTTP_GET的一般配置代码如下:
其中,digest表示加密期望值。在实际使用场景中,我们可以先获取一次正常的后端服务器的返回值,并对该返回值加密获得。
在某些情况下,上述两种健康检查是不能满足业务需求的。比如,业务有自己的判断健康命令;又如,业务是一个UDP的负载均衡服务。Keepalived专门提供了一个自定义的健康检查接口来满足这种情况,它可以根据自定义的命令/脚本运行后的返回值来判断后台服务器是否健康。在一般情况下,exit 0表示健康检查正常,exit 1表示健康检查失败。下面是对自定义的UDP的514端口进行健康检查的方法:
事实上,MISC_CHECK还有动态调整后端服务器权重的作用。当负载均衡调度算法为加权调度时,如果在MISC_CHECK内配置了misc_dynamic并且自定义监控的返回值是2~255,则对应的后台服务器的权重就会被调整为返回值再减去2。例如,健康检查的返回值是255,则权重会被调整为255-2=253。
3.2.2 使用VRRP实现主备
Keepalived很重要的一个功能就是可以实现主备模式的集群化四层负载均衡器。在通常情况下,我们将两台服务器配置成主从模式。即一台是MASTER,另一台是BACKUP。
MASTER 会 不 停 地 往 外 发 送 虚 拟 路 由 冗 余 协 议 ( Virtual RouterRedundancy Protocol,VRRP)的多播信号,当BACKUP接收到这个多播信号,并判断这个虚拟路由器标识符(Virtual Router ID,VRID)属于自己的组时,就会强制让自己静默(自己是指BACKUP,不要有接管VIP这类的行为)。
当BACKUP接收不到正常的VRRP多播信号时,就会认为MASTER已经出现故障,这时 BACKUP 就 会 切 换 成 MASTER 来 接 管 VIP , 并 发 送 免 费 ARP 报 文(gratuitousARP),同时发出VRRP数据包。当MASTER服务器重新恢复服务,发送出VRRP数据包后,BACKUP机器就会发现自己的优先级没有MASTER发出的VRRP优先级高,会再次把自己设置为BACKUP,并摘除自己的VIP。MASTER在恢复服务后会发现自己的优先级最高,占据MASTER的状态重新接管VIP,发送免费ARP。这样的主备模式可以确保在MASTER正常工作时,流量一直在MASTER上;当MASTER异常时,流量可以切换到BACKUP。
常见的VRRP主备配置代码如下:
其中,virtual_router_id在一个网段内的一组主备机器上需要保证一致,并且在该网段内需要有唯一性,否则就会导致VRID冲突及主备模式不可用。priority为主备各自的优先级配置,要确保MASTER的priority的值大于BACKUP的priority的值。advert_int表示发送VRRP数据包的周期,它会影响主备切换的时间效率。advert-int的值越小主备切换的感知速度就会越快,数据包发送频率也就会越快,对服务器的资源耗费显然也会越大。
3.2.3 使用ECMP实现集群化
从3.2.2节中我们知道,可以使用VRRP实现主备的集群模式。但是主备模式的瓶颈是一个VIP最多只能有一台机器的吞吐量。我们能否像后端服务器一样横向扩展负载均衡集群呢?答案是肯定的。通常,我们采用ECMP来实现VIP的分流,依托的软件就是Quagga。
ECMP(Equal-Cost Multi Path Routing,等价多路径路由协议)主要应用在路由策略上。比如,当某一个节点发现发往下一跳的多个路由都是最佳路径时,就会根据一定的策略将数据包分发到不同的下一跳。在通常情况下,为了确保一个数据流都分发到同一个下一跳,这个策略一般是哈希算法。
OSPF是一个支持ECMP的内部网关协议,它是一种动态的路由协议,通过在同网段内传输一个组播的数据包来让所有的路由器感知自己这个邻居节点。如果想要实现集群化的负载均衡服务,就需要依赖动态路由协议自动摘除故障负载均衡器,并在集群扩容时,自动加入新的负载均衡器。如果是静态路由协议,某个节点发生故障后下线,就无法实现自动摘除。
Quagga是一款集成了OSPF、RIP及BGP在内的多种路由协议的软件。我们通常使用OSPF来实现集群化(在Quagga中对应进程ospfd)。对于Quagga来说,ospfd进程的配置文件中可以进行如下配置:
172.27.11.140/26是交换机和服务器的互连路由,服务器上的OSPF通过network的方式将它发布出去。redistribute connected命令表示OSPF将所有本地的直连路由发布出去,由于负载均衡的业务VIP的路由都是直连路由,所以该命令相当于发布了所有VIP的路由。其余具体字段的信息可以查看Quagga官网,本节不再赘述。
我们依托上述协议,使用Quagga在服务器上模拟路由器节点,利用OSPF对外发布VIP的路由。交换机和服务器采用互连IP互相通信,并通过OSPF动态路由协议实现邻居感知和路由发现。如果一个负载均衡集群中的多台服务器同时发布相同的VIP路由,则交换机能通过OSPF发现存在多个路径到该VIP。如果各个路径的优先级和链路质量相同,则交换机认为这些路径是等价的,并按照等价路由的流量分发策略把该VIP的数据包分发到多台负载均衡服务器上。
3.2.4 使用网卡绑定扩展单网卡流量
网卡绑定是一种常用的技术。可以将多张网卡绑定成一个虚拟网卡。网卡绑定有不同的绑定模式,通常需要交换机配合。以两张网卡绑定为例,可以让其中一张网卡有流量,另一张网卡做备份。也可以使两张网卡都承载流量,达到横向扩展的目的。关于网卡绑定的细节,读者可以通过互联网搜索相关资料,本节对此不再做详细介绍。
本文给大家讲解的内容是负载均衡功能-高可用性
- 下篇文章给大家讲解负载均衡功能-高可扩展性
相关推荐
- Python爬虫进阶教程(二):线程、协程
-
简介线程线程也叫轻量级进程,它是一个基本的CPU执行单元,也是程序执行过程中的最小单元,由线程ID、程序计数器、寄存器集合和堆栈共同组成。线程的引入减小了程序并发执行时的开销,提高了操作系统的并发性能...
- A320-V2500发动机系统FADEC介绍(2)
-
目的全权数字发动机控制(FADEC)系统在所有飞行和运行阶段提供全范围发动机控制。...
- 三国志战棋版:玩家“二叔”用这套群DOT在比武中拿下31胜5负
-
声明:本文首发于今日头条,而后发布于“鼎叔闯三棋”的微信公众号、抖音、哔哩哔哩和小红书平台,如果在其他平台就是抄袭。...
- 真正的独一无二:Dot One 推出 DNA 定制系列 139英镑起
-
相信很多人在挑选衣物时有着这样的困扰,综合了性价比、面料等因素后好不容易找到了心仪的款式,还要担心是否会撞衫,不管是擦肩而过的陌生人还是身边的熟人,都令人尴尬。小部分人为此热衷于购买少量的古着或者限量...
- 崩铁:周年庆福利再升级,老角色加强时间确定,3.xdot体系反转
-
#埃安UT大一圈高级很多#...
- Dotgo推出RBMHub,扩大了CPaaS提供商的覆盖范围和功能
-
据telecompaper网7月15日报道,用于商业消息传递的RichCommunicationServices(RCS)解决方案的领先提供商Dotgo宣布推出RBMHub。RBMHub的推出扩大了C...
- 深度解析:快照取消Dot职业的将何去何从
-
写在前面曾几何时,术士的出现便被冠以dot大师的名头,从远古时期的献祭腐蚀虹吸不如暗牧一个痛,到TBC上满dot=荣誉击杀+1,到wlk接近全暴击的冰晶腐蚀,再到CTM就算了吧MOP的各种变态吸x放...
- 星穹铁道:抽卡芙卡之前,你必须了解什么是dot!
-
卡妈终于上线了,可还是有很多人不明白什么是dot伤害,抽了卡妈直接玩起了直伤流,把一个持续伤害的引爆器玩成了打手,卡妈打dot伤害是远高于直伤的,有了卡妈的玩家一直了解dot,不然这卡妈就真被玩成四不...
- 游戏界的闪耀星辰陨落:悼念知名游戏博主″dotα牛娃″
-
无尽哀思!在数字时代浪潮中,游戏不仅是消遣娱乐的代名词,更是连接心灵的桥梁,构筑了无数人的青春回忆。在这片浩瀚无垠的游戏宇宙中,有这样一位博主,他以独特的风采、深邃的洞察力和无尽的热情,成为了玩家心中...
- 直击2017新加坡同性恋聚会Pink Dot,自由爱!
-
今年的“粉红点”又来啦~这个支持LGBT群体(男女同志、双性恋、跨性别等)群体的活动,从2009年起,已经在新加坡举办8年了!”这个非营利的同性恋权益活动,主要是希望大家了解到,不管一个人的性倾向或...
- python-dotenv,一款超级实用处理环境变量python库
-
python-dotenv,一款超级实用处理环境变量python库python-dotenv概述:...
- 亚马逊语音助手毫无征兆发笑 诡异至极吓坏用户
-
来源:新华网美国电商亚马逊7日承诺,将更改名下“亚历克萨”语音系统设置,令它不会莫名发笑,免得吓坏用户。“亚历克萨”是亚马逊开发的语音助手软件,可服从用户语音指令完成对话、播放音乐等任务。依照原来设计...
- 2022最火英文网名男女生
-
精选好听英文昵称带翻译1.moveon(离开)2.Monster(怪物)3.Solo吉他手4.Finish.(散场)...
- 智能家具 RecycleDot 的出现给传统家具厂商带来新的挑战
-
从可穿戴手环、手表到智能衣服,智能硬件逐步渗透到每一个领域。最近有一对父子MikeSandru和JohnSandru在自家的车库中设计了一款智能家具RecycleDot,给日渐萧条的家具行...
- 欧洲通信卫星公司 OneWeb 敦促印度DoT尽早批准提供卫星宽带服务
-
据telecomtalk2月17日报道,欧洲通信卫星公司EutelsatOneWeb近日敦促印度电信部(DoT)尽快批准其在印度部署双地球站网关的计划,以便连接其近地轨道(LEO)全球卫星星座,并...