百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

一篇文章把负载均衡的高可用性给大家讲明白!

haoteby 2025-03-17 18:16 54 浏览

高可用性

负载均衡器本身的一个重要作用就是提供高可用性。

另外,其本身也需要是一个高可用的系统。

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 使用网卡绑定扩展单网卡流量

网卡绑定是一种常用的技术。可以将多张网卡绑定成一个虚拟网卡。网卡绑定有不同的绑定模式,通常需要交换机配合。以两张网卡绑定为例,可以让其中一张网卡有流量,另一张网卡做备份。也可以使两张网卡都承载流量,达到横向扩展的目的。关于网卡绑定的细节,读者可以通过互联网搜索相关资料,本节对此不再做详细介绍。

本文给大家讲解的内容是负载均衡功能-高可用性

  • 下篇文章给大家讲解负载均衡功能-高可扩展性

相关推荐

BRICS continues to offer powerful alternative global vision

Leadersattendingtheplenarysessionof"PeaceandSecurityandReformofGlobalGovernance"ofthe...

China's role in shaping global growth takes the stage at Summer Davos

Guestsattendtheparallelsession"CheckingInontheEnergyTransition"duringthe2025SummerDav...

Shanghai blockchain park proves WAIC's worth

BySHEXiaochenThe2023WorldArtificialIntelligenceConferencekickedoffinShanghaionThursday...

Shopee新手指南:Shopee卖家中心用户界面介绍

1.Shopee各站点前台网页链接:2.Shopee各站点后台网页链接3.ShopeeAPP下载:安卓版下载链接:https://pan.baidu.com/s/1eSp8M1k#list/path...

打孩子犯法!日本拟立法禁止父母体罚孩子

日本虐童事件频发引发了社会的广泛关注。近日,日本打算对现行的儿童福利法案进行修订,禁止父母体罚子女,但也引发了网友对于体罚、虐待以及法律可行性的讨论。日本将禁止父母体罚子女ViaJapanTod...

新NAS到手后,你一定要学会的9个设置,威联通和群晖都是这样的。

本内容来源于@什么值得买APP,观点仅代表作者本人|作者:小曹老师心念已久的NAS,终于到手了,期待着他能给我们数字化生活,带来更多的便捷和安心。...

苹果四大系统信息汇总(苹果手机系统分别有哪些)

【环球科技综合报道】据国外科技网站报道,苹果在6月13日举行全球开发者大会(WWDC),对iOS、MacOS、WatchOS、TVOS四大系统进行更新。MacOS:OSX系统将更名为“ma...

关于苹果iOS 10 系统 你需要了解的5个特点

【环球科技综合报道】据外媒5月10日报道,苹果公司将于今年6月举办全球开发者大会(WWDC)。在大会上,公司计划发布iOS10操作系统。该系统在iOS7操作系统的基础上进行了革新,具有里程碑式意义...

Win10用户:不要尝试安装Media Center

IT之家(www.ithome.com):Win10用户:不要尝试安装MediaCenter本月初,微软正式发布了Win10技术预览版。最近有部分用户尝试通过Win8.1的安装密钥,来为Window...

半年做到美妆Top主播,“成分测评师李某人”究竟何许人?

从毛毛姐到口红一哥李佳琦,男网红主播成为了一个趋势,也有越来越多的男生开始扎堆进入美妆行业,淘宝主播“成分测评师李某人”是其中之一。只是,他做主播的初衷,倒不是为了当网红,而是想给自己的美妆品牌打开一...

《经典怀旧手游》新手必看玩法,背景玩法详细介绍!

经典重温,武林再现,十年经典,再创江湖!备受玩家期待的《武林外传十年之约手游》即将来袭。本次版本主题为“江湖再现”,全新开放的梦境机关城将带来全新挑战!塑魂系统的全面升级,新增第二期空位和道具将大幅提...

17个问题,帮你判断咨询师是否适合自己

...

关于软考你想知道的都在这(软考有用吗 知乎)

软考相信学计算机的大家多多少少有过了解,就是全国计算机技术与软件专业技术资格(水平)考试,适用于大部分计算机同学和想转行IT行业的同学。这两天各省陆续出了报考的入口,大家可以积极报考!软考含金量较高,...

微软面向Linux平台放出4.3版本Skype

继日前微软针对iPhone平台放出5.0版本Skype,对用户界面进行多处调整之后软再次面向Linux平台放出了4.3.0.37版本Skype应用,带来了部分用户界面改善、全新的功能和系统后台性能优化...

Linux dd命令有多强大?(linux的dig命令)

请关注本头条号,每天坚持更新原创干货技术文章。如需学习视频,请在微信搜索公众号“智传网优”直接开始自助视频学习1.前言本文主要介绍Linuxdd命令的强大功能与日常的使用案例。Linux中的dd命...