常用负载均衡及策略图解

article/2025/10/28 23:31:35

文章目录

    • 一、负载均衡
    • 二、负载均衡模型分类
    • 三、CDN负载均衡
    • 四、LVS负载均衡
      • 4.1 LVS 支持的三种模式
        • 4.1.1 DR 模式
        • 4.1.2 TUN 模式
        • 4.1.3 NAT 模式
      • 4.2 LVS 基于 Netfilter 的框架实现
    • 五、负载均衡策略是什么
    • 六、常用负载均衡策略图解
      • 6.1 轮询
      • 6.2 加权轮询
      • 6.3 最少连接数
      • 6.4 最快响应
      • 6.5 Hash 法
    • 七、用健康探测来保障高可用
      • 7.1 HTTP 探测
      • 7.2 TCP 探测
      • 7.3 UDP 探测

一、负载均衡

负载均衡是云计算的基础组件,是网络流量的入口,其重要性不言而喻。

什么是负载均衡呢?
将用户请求或者说流量通过负载均衡器,按照某种负载均衡算法把流量均匀地分散到后端的多个服务器上,接收到请求的服务器可以独立的响应请求,以期望的规则分摊到多个操作单元上进行执行,达到负载分担的目的。并通过它可以实现横向扩展(scale out),将冗余的作用发挥为高可用。

二、负载均衡模型分类

从应用场景上来说,常见的负载均衡模型有全局负载均衡和集群内负载均衡,从产品形态角度来说,又可以分为硬件负载均衡和软件负载均衡。

全局负载均衡一般通过 DNS 实现,通过将一个域名解析到不同 VIP,来实现不同的 Region 调度能力。

硬件负载均衡器常见的有 F5、A10、Array,它们的优缺点都比较明显,优点是功能强大,有专门的售后服务团队,性能比较好;缺点是缺少定制的灵活性,维护成本较高。

现在的互联网更多的思路是通过软件负载均衡来实现,这样可以满足各种定制化需求,常见的软件负载均衡有 LVS、Nginx、Haproxy。
在这里插入图片描述
对于用户配置的四层监听,LVS 后面会直接挂载用户 ECS,七层用户监听 ECS 则挂载在 Tengine 上。四层监听的流量直接由 LVS 转发到 ECS,而七层监听的流量会经过 LVS 到 Tenigine 再到用户 ECS。

每一个 Region 里都会有多个可用区,达到主备容灾目的,每一个集群里都有多台设备,第一是为了提升性能,第二也是基于容灾考虑。
在这里插入图片描述
上图为高性能负载均衡控制管理概要图,SLB 产品也有 SDN 概念,转发和控制是分离的,用户所有配置通过控制台先到控制器,通过集中控制器转换将用户配置推送到不同设备上,每台设备上都有 Agent 接收控制器下发的需求。

通过本地转换成 LVS 和 Tengine 能够识别的配置,这个过程支持热配置,不影响用户转发,不需要 reload 才能使新配置生效。

三、CDN负载均衡

四、LVS负载均衡

4.1 LVS 支持的三种模式

在这里插入图片描述
早期 LVS 支持以下三种模式:DR 模式、TUN 模式、NAT 模式

4.1.1 DR 模式

DR 模式经过 LVS 之后,LVS 会将 MAC 地址更改、封装 MAC 头,内层 IP 报文不动。

报文经过 LVS 负载均衡查找到 RS 之后,将源 MAC 头改成自己的,目的 MAC 改成 RS 地址,MAC 寻址是在二层网络里,对网络部署有一定的限定,在大规模分布式集群部署里,这种模式的灵活性没有办法满足需求。

4.1.2 TUN 模式

TUN 模式走在 LVS 之后,LVS 会在原有报文基础上封装 IP 头,到了后端 RS 之后,RS 需要解开 IP 报文封装,才能拿到原始报文。

不管是 DR 模式还是 TUN 模式,后端 RS 都可以看到真实客户源 IP,目的 IP 是自己的 VIP,VIP 在 RS 设备上需要配置,这样可以直接绕过 LVS 返回给用户。

TUN 模式问题在于需要在后端 ECS 上配置解封装模块,在 Linux 上已经支持这种模块,但是 Windows 上还没有提供支持,所以会对用户系统镜像选择有限定。

4.1.3 NAT 模式

NAT 模式用户访问的是 VIP,LVS 查找完后会将目的 IP 做 DNAT 转换,选择出 RS 地址。

因为客户端的 IP 没变,在回包的时候直接向公网真实客户端 IP 去路由,NAT 的约束是因为 LVS 做了 DNAT 转换,所以回包需要走LVS,把报文头转换回去。

由于 ECS 看到的是客户端真实的源地址,我们需要在用户 ECS 上配置路由,将到 ECS 的默认路由指向 LVS 上,这对用户场景也做了限制。

4.2 LVS 基于 Netfilter 的框架实现

在这里插入图片描述
Netfilter 是 Linux 提供的网络开放平台,基于该平台可以开发自己的业务功能模块,早期好多安全厂商都是基于 Netfilter 做一些业务模型实现。

这种模型比较灵活,但通用模型里更多的是兼容性考虑,路径会非常长;而且通用模型中没办法发挥多核特性,目前 CPU 的发展更多是向横向扩展。

我们经常见到多路服务器,每路上有多少核,早期通用模型对多核支持并不是特别友善,在多核设计上有些欠缺,导致我们在通用模型上做一些应用开发时的扩展性是有限的,随着核的数量越来越多,性能不增反降。

五、负载均衡策略是什么

在这里插入图片描述
正如上图所示的这样,由一个独立的统一入口来收敛流量,再做二次分发的过程就是负载均衡,它的本质和分布式系统一样,是分治。在软件系统中为了避免流量分摊不均,造成局部节点负载过大(如 CPU 吃紧等),所以引入一个独立的统一入口来做类似的工作。
在软件系统中的负载均衡的背后是策略在起作用,而策略的背后是由某些算法或者说逻辑来组成的。负载均衡,也有很多算法或者说逻辑在支撑着这些策略,也有静态和动态之分。

六、常用负载均衡策略图解

下面来罗列一下日常工作中最常见的 5 种策略。

6.1 轮询

在这里插入图片描述
这是最常用也最简单策略,平均分配,人人都有、一人一次。大致的代码如下:

int  globalIndex = 0;   //注意是全局变量,不是局部变量。try{return servers[globalIndex];
} finally {globalIndex++;if (globalIndex == 3)globalIndex = 0;
}

6.2 加权轮询

在这里插入图片描述
在轮询的基础上,增加了一个权重的概念。权重是一个泛化后的概念,可以用任意方式来体现,本质上是一个能者多劳思想。

比如,可以根据宿主的性能差异配置不同的权重。大致的代码如下:

int matchedIndex = -1;
int total = 0;for (int i = 0; i < servers.Length; i++)
{servers[i].cur_weight += servers[i].weight;//①每次循环的时候做自增(步长=权重值)total += servers[i].weight;//②将每个节点的权重值累加到汇总值中if (matchedIndex == -1 || servers[matchedIndex].cur_weight < servers[i].cur_weight) //③如果 当前节点的自增数 > 当前待返回节点的自增数,则覆盖。{matchedIndex = i;}
}servers[matchedIndex].cur_weight -= total;//④被选取的节点减去②的汇总值,以降低下一次被选举时的初始权重值。
return servers[matchedIndex];

这段代码的过程如下图的表格。"()"中的数字就是自增数,即代码中的 cur_weight。
在这里插入图片描述

值得注意的是,加权轮询本身还有不同的实现方式,虽说最终的比例都是 2:1:2。

但是在请求送达的先后顺序上可以有所不同。比如「5-4,3,2-1」和上面的案例相比,最终比例是一样的,但是效果不同。

「5-4,3,2-1」更容易产生并发问题,导致服务端拥塞,且这个问题随着权重数字越大越严重。

例子:10:5:3 的结果是「18-17-16-15-14-13-12-11-10-9,8-7-6-5-4,3-2-1」

6.3 最少连接数

在这里插入图片描述
这是一种根据实时的负载情况,进行动态负载均衡的方式。维护好活动中的连接数量,然后取最小的返回即可。大致的代码如下:

var matchedServer = servers.orderBy(e => e.active_conns).first();
matchedServer.active_conns += 1;
return matchedServer;//在连接关闭时还需对active_conns做减1的动作。

6.4 最快响应

在这里插入图片描述
这也是一种动态负载均衡策略,它的本质是根据每个节点对过去一段时间内的响应情况来分配,响应越快分配的越多。

具体的运作方式也有很多,上图的这种可以理解为,将最近一段时间的请求耗时的平均值记录下来,结合前面的加权轮询来处理,所以等价于 2:1:3 的加权轮询。

**题外话:**一般来说,同机房下的延迟基本没什么差异,响应时间的差异主要在服务的处理能力上。

如果在跨地域(例:浙江->上海,还是浙江->北京)的一些请求处理中运用,大多数情况会使用定时「Ping」的方式来获取延迟情况,因为是 OSI 的 L3 转发,数据更干净,准确性更高。

6.5 Hash 法

在这里插入图片描述
Hash 法的负载均衡与之前的几种不同在于,它的结果是由客户端决定的。通过客户端带来的某个标识经过一个标准化的散列函数进行打散分摊。上图中的散列函数运用的是最简单粗暴的取余法。

**题外话:**散列函数除了取余之外,还有诸如变基、折叠、平方取中法等等,此处不做展开,有兴趣的小伙伴可自行查阅资料。

另外,被求余的参数其实可以是任意的,只要最终转化成一个整数参与运算即可。

最常用的应该是用来源 IP 地址作为参数,这样可以确保相同的客户端请求尽可能落在同一台服务器上。

常用负载均衡策略优缺点和适用场景

我们知道,没有完美的事物,负载均衡策略也是一样。上面列举的这些最常用的策略也有各自的优缺点和适用场景,我稍作了整理,如下。
在这里插入图片描述
这些负载均衡算法之所以常用也是因为简单,想要更优的效果,必然就需要更高的复杂度。

比如,可以将简单的策略组合使用、或者通过更多维度的数据采样来综合评估、甚至是基于进行数据挖掘后的预测算法来做。

七、用健康探测来保障高可用

不管是什么样的策略,难免会遇到机器故障或者程序故障的情况。所以要确保负载均衡能更好的起到效果,还需要结合一些健康探测机制。定时的去探测服务端是不是还能连上,响应是不是超出预期的慢。

如果节点属于“不可用”的状态的话,需要将这个节点临时从待选取列表中移除,以提高可用性。一般常用的健康探测方式有 3 种。

7.1 HTTP 探测

使用 Get/Post 的方式请求服务端的某个固定的 URL,判断返回的内容是否符合预期。一般使用 HTTP 状态码、Response 中的内容来判断。

7.2 TCP 探测

基于 TCP 的三次握手机制来探测指定的 IP + 端口。最佳实践可以借鉴阿里云的 SLB 机制,如下图:
在这里插入图片描述
值得注意的是,为了尽早释放连接,在三次握手结束后立马跟上 RST 来中断 TCP 连接。

7.3 UDP 探测

可能有部分应用使用的是 UDP 协议。在此协议下可以通过报文来进行探测指定的 IP + 端口。最佳实践同样可以借鉴阿里云的 SLB 机制,如下图:
在这里插入图片描述
结果的判定方式是:在服务端没有返回任何信息的情况下,默认是正常状态。否则会返回一个 ICMP 的报错信息。


http://chatgpt.dhexx.cn/article/plBAjl31.shtml

相关文章

关于0范数、1范数和无穷范数

若 则p范数 p取0时对应0范数&#xff0c;p取1时对应1范数&#xff0c;p取无穷大时对应无穷范数 //LaTeX真的好用 【注意理解】当p取无穷大时&#xff0c;最终只与元素中绝对值最大的元素有关&#xff0c;证明如下&#xff1a;

向量和矩阵的 1范数、2范数

1.向量的范数&#xff1a;0范数&#xff0c;向量中非零元素的个数。 1范数&#xff0c;为绝对值之和。 2范数&#xff0c;就是通常意义上的模。 无穷范数&#xff0c;就是取向量的最大值。 但是向量的范数和矩阵的范数关系不大&#xff0c;百度了好久也没看到狠心的东西&…

向量的范数norm:1范数、2范数、无穷范数;矩阵的行范数、列范数

0范数&#xff1a; 向量中非零元素的个数。1范数&#xff1a; 为绝对值之和。2范数&#xff1a; 通常意义上的模。无穷范数&#xff1a;取向量的最大值。 转自&#xff1a;范数对于数学的意义&#xff1f;1范数、2范数、无穷范数

向量的1范数,2范数,无穷范数,KNN中的Lp距离

L-0范数&#xff1a;用来统计向量中非零元素的个数。 L-1范数&#xff1a;向量中所有元素的绝对值之和。 L-2范数&#xff1a;欧式距离。 L-∞范数&#xff1a;计算向量中的最大值。 你也可以这样理解 1-范数&#xff1a; ║ x ║ 1 │ x 1 │ │ x 2 │ … │ x n │ ║…

范数与模

复数的模 向量的范数 范数&#xff0c;在机器学习中通常用于衡量一个向量的大小&#xff0c;范数的定义如下&#xff1a; P>1 比如如下常见的范数 1-范数&#xff1a;║x║1│x1││x2│…│xn│ &#xff08;曼哈顿距离&#xff09; 2-范数&…

求矩阵的1,和2范数

1.向量的范数&#xff1a;0范数&#xff0c;向量中非零元素的个数。 1范数&#xff0c;为绝对值之和。 2范数&#xff0c;就是通常意义上的模。 无穷范数&#xff0c;就是取向量的最大值。 但是向量的范数和矩阵的范数关系不大&#xff0c;百度了好久也没看到狠心的东西&…

矩阵L2,1范数及矩阵L2,p范数的求导

常见的矩阵范数有L1&#xff0c;L2&#xff0c; ∞ 范数&#xff0c;F范数和引申出的L2,1范数。而在机器学习的特征选择中&#xff0c;利用选择矩阵的范数对选择矩阵进行约束&#xff0c;即是正则化技术&#xff0c;是一种稀疏学习。 L0 &#xff0c; L1 向量范数 L0 范数 L0 …

计算方法 | 范数(向量:1范数、2范数、无穷范数;矩阵:行范数、列范数)

0范数&#xff1a; 向量中非零元素的个数。1范数&#xff1a; 为绝对值之和。2范数&#xff1a; 通常意义上的模。无穷范数&#xff1a;取向量的最大值。 行范数&#xff1a;矩阵中每行绝对值之和的最大值列范数&#xff1a;矩阵中每列绝对值之和的最大值 详细研究请访问&#…

到底什么是范数?什么是0范数、1范数、2范数?区别又是什么?

其实我的专业不是数学专业&#xff0c;只不过在阅读paper时&#xff0c;我们会经常看到0范数或者1范数这些范数问题。本文就来分析看看到时什么是范数&#xff1f;什么是0范数、1范数、2范数&#xff1f;它们的区别又是什么&#xff1f;为了方便某些着急的people&#xff0c;先…

向量和矩阵的各种范数比较(1范数、2范数、无穷范数等等)

一、向量的范数 首先定义一个向量(一般用列向量表示)为&#xff1a; 1.1 向量的1范数 向量的1范数即&#xff1a;向量的各个元素的绝对值之和&#xff0c;上述向量a的1范数结果就是&#xff1a;29&#xff0c;MATLAB代码实现为&#xff1a;norm&#xff08;a&#xff0c;1&am…

未为python配置解释器_Python环境安装,解释器配置

下载安装完Pycharm后&#xff0c;创建一个py文件编写代码会提示No Python interpreter configured for the project&#xff0c;这是提示要配置解释器&#xff0c;可以去官网下载安装。 从官网下载https://www.python.org/downloads/windows/ 以我的电脑为例&#xff0c;选择64…

Python开发环境安装及配置

提示&#xff1a;在Python中&#xff0c;一切皆为对象 文章目录 前言初始PythonPyCharm开发环境主要包括以下特点&#xff1a;一、Python自带编辑器IDLE使用二、Anaconda集成环境安装及使用Anaconda环境创建 三、PyCharm环境安装及使用 前言 提示&#xff1a;这里可以添加本文…

2021最新版Python环境安装变量配置超详细教程,看了就会

Python都更新到3.10最新版本了&#xff0c;赶快下载更新&#xff0c;新功能很香。本文图文并茂教你安装和变量配置&#xff0c;我保证你看了就会&#xff0c;小白赶快学起来。先了解下新功能有哪些。 目录 一、Python 3.10 相比 3.9 的新增特性 带圆括号的上下文管理器 更清楚的…

超详细的Python安装和环境搭建教程

目录 安装简介&#xff1a; 第一步&#xff0c;下载Python 第二步&#xff0c;安装Python 1.勾选 And Python 3.9 PATH 选项 2.选择自定义安装(Cutormize installation) 第三步&#xff0c;检查Python是否正常安装成功 安装错误 1.重复安装 2.Python不是内部命令或外部命…

Python教程一:Python环境安装(Anaconda3版本)

前言 Anaconda包括Conda、Python及大部分集成的工具包。 初学者建议直接安装Anaconda3会省去很多工具包的安装过程。 优势&#xff1a;若新建一个项目或者使用不同于Anoconda装的基本Python版本&#xff0c;Anoconda就可以实现同时多个python版本的管理。 注&#xff1a;安…

Linux安装Python环境

本文基于如下Linux系统版本&#xff1a; 1、默认情况下&#xff0c;Linux会自带安装Python&#xff0c;可以运行python --version命令查看&#xff0c;如图&#xff1a; 我们看到Linux中已经自带了Python2.7.5。再次运行python命令后就可以使用python命令窗口了&#xff08;C…

详解离线安装Python库

大家好,我是爱编程的喵喵。双985硕士毕业,现担任全栈工程师一职,热衷于将数据思维应用到工作与生活中。从事机器学习以及相关的前后端开发工作。曾在阿里云、科大讯飞、CCF等比赛获得多次Top名次。现为CSDN博客专家、人工智能领域优质创作者。喜欢通过博客创作的方式对所学的…

macOS Python安装教程

1在地址栏里输入https://www.python.org/,这是python的官网&#xff0c;进入python官网 &#xff08;之前一直打不开页面&#xff0c;后来发现自己在/etc/hosts 中配置了&#xff1a; 0.0.0.0 account.jetbrains.com 0.0.0.0 www.jetbrains.com &#xff09;…

python环境安装(一)

之前安装过很多次了&#xff0c;但是每次到新电脑上或者版本更新后都又要找在线教程。今天打算把流程写下来&#xff0c;便于以后随便在其他电脑上可以安装。 步骤一&#xff1a; 打开python官网&#xff0c;找到下载地址&#xff1a;https://www.python.org/downloads/下载需…