全面了解 NGINX 的负载均衡算法

server/2024/10/24 1:57:47/

NGINX 提供多种负载均衡方法,以应对不同的流量分发需求。常用的算法包括:最少连接、最短时间、通用哈希、随机算法和 IP 哈希。这些负载均衡算法都通过独立指令来定义,每种算法都有其独特的应用场景。

image.png

以下负载均衡方法(IP 哈希除外)适用于 HTTP、TCP 和 UDP 上游池:

轮询

轮询(Round Robin)是 NGINX 默认的负载均衡方法,按服务器列表的顺序分发请求。此方法适用于所有服务器具有相似性能的场景。加权轮询:如果服务器的处理能力不同,可以通过 weight 参数进行权重设置。权重越高,服务器接收的请求越多。加权轮询的基本原理是通过加权平均值来决定流量分配。

最少连接

least_conn 方法通过将请求代理到当前连接数最少的服务器,帮助优化资源利用率。它非常适用于处理长时间连接(如 WebSocket)的场景。权重同样可以结合使用,以进一步控制负载分配。

最短时间

least_time 仅在 NGINX Plus 中提供,是一种更加智能的负载均衡算法。它不仅考虑服务器的连接数,还优先选择响应时间最短的服务器。这种方法特别适合高性能应用,能够帮助减少延迟并提高响应速度。

参数设置:用户需指定 header(使用响应头的时间)或 last_byte(使用完整响应的时间)作为优化依据。可选参数 inflight 还可以将未完成的请求考虑在内。

通用哈希

hash 算法根据管理员定义的哈希值(基于请求的特定文本、变量或两者结合)将请求定向到特定服务器。这种方法在需要请求始终发往同一服务器的场景(如缓存或会话一致性)中非常有用。

注意事项:当服务器池发生变化(添加或删除服务器)时,哈希分配会重新计算,因此某些会话可能会重新路由。

随机算法

random 算法用于在服务器池中随机选择一台服务器处理请求。它支持 weight 参数来影响服务器的选择概率。通过 two [method] 参数,NGINX 可随机选择两台服务器,并使用指定的负载均衡方法(如 least_conn)在这两台服务器间分配请求。

IP 哈希

ip_hash 仅适用于 HTTP 协议。此方法基于客户端 IP 地址的哈希值,将请求分配到特定服务器。使用此方法可以确保来自同一客户端的请求始终被分发到同一台服务器,特别适合需要维持会话一致性的应用场景。

IP 哈希的工作原理:IP 哈希算法使用 IPv4 地址的前三个八位组或完整的 IPv6 地址生成哈希值。这不同于通用哈希算法,后者使用远程变量来生成哈希。

最后

每种负载均衡算法都有其独特的优势和应用场景,结合需求,合理选择负载均衡方法能够显著提升系统的性能和可用性


http://www.ppmy.cn/server/134320.html

相关文章

【重学 MySQL】六十七、解锁检查约束,守护数据完整性

【重学 MySQL】六十七、解锁检查约束,守护数据完整性 检查约束的基本概念检查约束的语法检查约束的使用场景注意事项示例 在MySQL中,检查约束(CHECK)是一种用于确保表中数据满足特定条件的约束。 检查约束的基本概念 检查约束用…

界面耻辱纪念堂--可视元素04

当我们第一次注意到 Visual Basic 5.0 菜单的动画效果“特性”时,我们只能嘲笑这种特性的傻气。事实上,我们并不觉得特性本身傻气,而是微软为这个特性投资,然后将这个特性应用到他们所有的主流产品(例如,Of…

上传文件到云存储前端报错413 Request Entity Too Large

访问上传接口控制台报错 详细原因 net::err_connection_reset,于是用postman测试报错 nginx 413 Request Entity Too Large 这个报错就很明显了,nginx对上传文件的大小有了限制,去看看nginx的配置就知道了。 client_max_body_size 100M; 设置…

【数学二】一元函数积分学-定积分的应用-平面图形面积、旋转体体积、函数的平均值、平面曲线的弧长、旋转曲面面积

考试要求 1、理解原函数的概念,理解不定积分和定积分的概念. 2、掌握不定积分的基本公式,掌握不定积分和定积分的性质及定积分中值定理,掌握换元积分法与分部积分法. 3、会求有理函数、三角函数有理式和简单无理函数的积分. 4、理解积分上限…

【Flutter】基础组件:文本及样式

在 Flutter 开发中,文本是最基本的 UI 元素之一。无论是简单的标题,还是复杂的富文本展示,Flutter 提供了强大的 Text 和相关的样式工具来满足开发需求。本教程将深入介绍 Text、TextStyle、TextSpan、DefaultTextStyle 及字体等内容&#xf…

【数据结构】滑动窗口算法详解:高效解决子串问题

滑动窗口(Sliding Window)是一种常用于处理数组或字符串中子序列问题的算法技巧。它通过维护一个窗口来限制待处理的数据范围,从而高效地解决问题,避免重复计算。它的时间复杂度通常为 O(N),相较于暴力破解&#xff08…

部署harbor问题(缺少ssl认证证书)

在部署harbor服务,/install.sh启动时,缺少ssl认证 1. 创建证书目录 首先,创建 /usr/local/harbor/ssl 目录: mkdir -p /usr/local/harbor/ssl 2. 生成私钥 生成一个 4096 位的 RSA 私钥: openssl genrsa -out /us…

Git 分支操作-开发规范

一、背景 在实际开发中,一般在主分支的基础上单独创建一个新的分支进行开发,最后合并到master分支,而不是直接在master分支进行开发。 二、新建分支 1、初始状态,local为本地分支,remote为远程分支 2、单击 “Remot…