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

Nginx负载均衡算法详解(5大主流算法)

haoteby 2025-06-03 22:02 8 浏览

关注mikechen十余年BAT架构经验倾囊相授!


大家好,我是mikechen睿哥。


Nginx是大型架构的必备中间件,也是大厂经常考察的内容,下面我就全面来详解Nginx算法@mikechen

轮询(Round Robin)

原理图解

轮询算法会将请求依次分发给各个后端服务器,不考虑服务器当前负载:

upstream backend {    server 192.168.1.101;    server 192.168.1.102;    server 192.168.1.103;} server {    location /{        proxy_pass http://backend;}}

Nginx默认使用轮询算法,按顺序分发请求。

请求1→后端A请求2→后端B请求3→后端C请求4→后端A……

优点与缺点

优点:

  • 实现简单
  • 默认启用,无需额外配置

缺点:

  • 忽略后端服务器的实际负载
  • 不适合性能差异明显的服务器集群

应用场景

  • 后端服务器性能相近
  • 请求处理时间差异不大


加权轮询(Weighted Round Robin)

加权轮询是对轮询的改进,通过为每台服务器分配权重来决定请求分发的频率,权重高的服务器会接收更多请求。

逻辑:假设服务器A权重为3,B为2,C为1,则请求分配比例为3:2:1。

A(权重5), B(权重1), C(权重1)

请求分发顺序示意:

A A A A A B C A A A A A B C …

动态权重调整技巧

可基于:

  • 健康检查结果
  • 后端负载实时反馈(需配合第三方模块)

例如:

server 192.168.1.101 weight=5;server 192.168.1.102 weight=1;

配置示例

upstream backend {    server backend1.example.com weight=3;    server backend2.example.com weight=2;    server backend3.example.com weight=1;}server {    location /{        proxy_pass http://backend;}}

这里服务器1处理50%的请求,服务器2处理33%,服务器3处理17%。


最少连接数(Least Connections)

最少连接数算法:根据后端服务器当前的活跃连接数来分配请求,新请求会被分发到连接数最少的服务器。



应用场景:

  • 后端服务器性能差异较大。
  • 应用中存在长连接或连接保持时间不确定的情况。
  • 需要根据服务器的实际负载进行动态调整的场景。

和RR对比分析

特性

Round Robin

Least Connections

实现复杂度

简单

略高

是否考虑负载

适用于

均衡场景

动态请求耗时场景

配置示例

upstream backend {    least_conn;    server backend1.example.com;    server backend2.example.com;    server backend3.example.com;} server {    listen 80;    server_name example.com;     location /{        proxy_pass http://backend;}}


源地址哈希(IP Hash)

请求分发图

IP Hash基于客户端IP地址进行哈希计算,分发请求:

hash(IP) % N(N为后端数量)

相同IP → 相同后端

保持会话的典型场景

  • 登录状态保持(Session粘性)
  • Cookie依赖于后端一致性时

配置示例

upstream backend {    ip_hash;    server backend1.example.com;    server backend2.example.com;    server backend3.example.com;} server {    listen 80;    server_name example.com;     location /{        proxy_pass http://backend;}}


一致性哈希(Consistent Hash)

【需第三方模块
nginx-upstream-consistent-hash

哈希环图解

使用一致性哈希将请求映射到“环”上的节点上:

  • 节点少量变化 → 映射关系局部变化,缓存命中率高
  • 增减节点对已有请求影响小

缓存一致性保障

适用于:

  • 分布式缓存系统(如 Memcached, Redis 集群)
  • 长连接保持会话粘性

典型使用场景(如动态节点)

  • 微服务节点频繁变更
  • 高并发、缓存敏感场景

以上


本篇已收于mikechen原创超30万字《阿里架构师进阶专题合集》里面。

相关推荐

单点登录(SSO)解决方案介绍(单点登录概念)

一、单点登录的介绍单点登录(SingleSignOn),简称为SSO,是目前比较流行的企业业务整合的解决方案之一。SSO的定义是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系...

系统登录的三种方式,哪一种更安全?

登录是一个高频的动作,笔者抓住这一个小点,分析了系统登录的几种方式和对应的场景。今天谈谈登录。登录即用户输入用户名和密码登录进系统中。B端系统,对于登录的业务场景有两种(可能不止,目前遇到过这两种):...

到底什么是单点登录(SSO)?(什么叫做单点登录)

什么是单点登录?单点登录(SingleSign-On,简称SSO)是一种集中式的身份验证和授权机制,用户只需在一处输入一次凭证(例如用户名和密码)就可以访问多个相关但独立的软件系统。在数字化时代,...

5年稳如老狗的单点登录系统,到底是怎么搞出来的?

说到单点登录(SingleSign-On,简称SSO),大家的第一反应可能是——啊不就是登录一次,能到处串门儿嘛?别说,还真差不多,就是这么个意思。但真要搭一套好用、耐造、还能扛住公司里各种奇奇怪...

这些负载均衡都解决哪些问题?服务、网关、NGINX?

在微服务项目中,有服务的负载均衡、网关的负载均衡、Nginx的负载均衡,这几个负载均衡分别用来解决什么问题呢?一、服务的负载均衡先抛出一个问题:...

Nginx负载均衡最全详解(4大算法原理机制)

Nginx在大型网站架构很重要,也是大厂重点考察方向,今天我就重点来详解Nginx负载均衡@mikechen本篇已收于mikechen原创超30万字《阿里架构师进阶专题合集》里面。Nginx负载均衡N...

负载均衡 Nginx Session 一致性(nginx 负载均衡 会话保持)

HTTPS请求跳转...

监控Oracle Cloud负载均衡器:Applications Manager释放最佳性能

设想你正在运营一个受欢迎的在线学习平台,在考试前的高峰期,平台流量激增。全球的学生同时登录,观看视频、提交作业和参加测试。如果OracleCloud负载均衡器不能高效地分配流量,或者后端服务器难...

Nginx负载均衡:nginx.conf配置文件说明!

大家好,欢迎来到程序视点!我是你们的老朋友.小二!在此记录下Nginx服务器nginx.conf负载均衡的配置文件说明,部分注释收集与网络.关于nginx.conf基本的配置,请查看上一篇文章!Ng...

Java高可用系统架构中的负载均衡策略

Java高可用系统架构中的负载均衡策略在现代的分布式系统中,负载均衡策略是构建高可用系统的基石。Java开发者需要深刻理解这些策略,以便打造稳定且高效的系统。接下来,让我们一起揭开负载均衡的神秘面纱。...

深入对比Nginx、LVS和HAProxy,选择最合适负载均衡方案!

关注...

Spring Boot3 客户端负载均衡全解析:从原理到实战

在当今互联网大厂后端技术开发的激烈竞争环境中,构建高效、稳定的微服务架构是核心诉求。其中,SpringBoot3作为热门开发框架,其客户端负载均衡功能对于提升系统性能、保障服务稳定性起着关键作用。...

MySql高可用集群MySQL Router负载均衡读写分离

名词解释MGR:MysqlGroupReplication组复制,多台MySQL服务器在同一组中会自动保持同步状态,当某台服务器故障时,整个复制组依然可以保持正常并对外提供服务。...

性能测试之tomcat+nginx负载均衡(nginx tomcat)

nginxtomcat配置准备工作:两个tomcat执行命令cp-rapache-tomcat-8.5.56apache-tomcat-8.5.56_2修改被复制的tomcat2下con...

win10/11双网卡链路聚合叠加负载均衡提升网速解决网卡网速瓶颈!

双网卡链路聚合一种网络配置技术,通过将多个物理网卡绑定在一起,形成一个逻辑上的网络接口,以提高网络的可靠性、可用性和性能。这种技术通常用于服务器和网络设备中,以实现负载均衡、冗余和高可用性。本机环境:...