当前位置: 首页 > news >正文

Nginx stream模块是连接级别的负载均衡

在Nginx的stream模块中,upstream的权重配置实现的是连接级别的负载均衡,这和http模块不同。
当客户端发起一个新的TCP连接时,Nginx根据各upstream的权重值选择其中一个upstream建立连接,之后该连接上的所有数据传输都由这个upstream处理。


核心机制

  1. 连接级别的负载均衡

    • 当客户端与Nginx建立TCP连接时,Nginx会根据upstream块中配置的权重(weight),选择一个后端服务器建立连接。
    • 一旦连接建立,该连接的所有数据通信都会固定转发到同一个后端服务器。即使客户端通过此连接发送多个请求(例如通过TCP长连接),所有请求仍会由同一个后端处理。
  2. 权重的具体作用

    • 权重(weight)决定了后端服务器接收新连接的比例。例如:
      upstream backend {server backend1.example.com weight=3;server backend2.example.com weight=1;
      }
      
      • 在此配置中,backend1会接收约75%的新连接(3/(3+1)),backend2接收约25%。
    • 权重通过加权轮询算法实现,Nginx会在多个连接建立时按权重比例分配后端。
  3. 与HTTP模块的区别

    • 在HTTP模块(如http块中的upstream)中,负载均衡可以基于请求级别(例如每个HTTP请求独立分配后端)。但stream模块工作在传输层(TCP/UDP),不解析应用层协议(如HTTP),因此只能在连接建立时决定后端,无法针对单个请求进行负载均衡。

详细原理

  1. 连接建立阶段

    • 客户端发起TCP连接请求到Nginx。
    • Nginx根据配置的负载均衡算法(默认为加权轮询)选择一个后端服务器。
    • Nginx与后端服务器建立连接,并将客户端连接绑定到此后端。
  2. 数据传输阶段

    • 客户端通过已建立的TCP连接发送数据,Nginx仅作为代理转发数据,不会中断连接或重新选择后端
    • 如果客户端断开并重新建立连接,Nginx会再次根据权重分配新的后端服务器。
  3. 支持的负载均衡算法

    • weight参数与轮询(round-robin)算法配合使用。
    • 其他算法如least_conn(最小连接数)或hash(一致性哈希)也可能影响分配逻辑,但权重仅在轮询算法中直接生效。

示例场景

  • 场景1:客户端建立100个TCP连接到Nginx。
    • 如果backend1权重为3,backend2权重为1,则大约75个连接分配给backend1,25个给backend2
  • 场景2:客户端通过单个TCP连接发送10个请求。
    • 所有10个请求均由同一个后端服务器处理,Nginx不会重新分配。

总结

  • 权重影响的是连接分配比例,而非单个请求。
  • 适合场景:需要长连接的TCP服务(如数据库、SSH、SMTP),其中连接的建立成本较高,保持连接固定到后端更高效。
  • 不适用场景:需要按请求动态分配负载的应用层协议(如HTTP短连接),此时应使用HTTP模块的负载均衡功能。
http://www.xdnf.cn/news/402877.html

相关文章:

  • [计算机科学#14]:数据结构
  • 现代化水库运行管理矩阵平台如何建设?
  • DNS域名解析服务器的部署
  • 2025 年福建省职业院校技能大赛网络建设与运维赛项Linux赛题解析
  • 基于STM32、HAL库的CH342K USB转UART收发器 驱动程序设计
  • Spring Boot 注解详细解析:解锁高效开发的密钥
  • 中科院无人机导航物流配送的智能变革!LogisticsVLN:基于无人机视觉语言导航的低空终端配送系统
  • C++类与对象(二):六个默认构造函数(一)
  • 基于Qt6 + MuPDF在 Arm IMX6ULL运行的PDF浏览器——MuPDF Adapter文档
  • 《Python星球日记》 第64天:NLP 概述与文本预处理
  • 深度学习与机器学习模型全景解析:适用场景与最优实践指南
  • 【高并发架构设计】-1:高并发通用设计思想
  • LayerNorm vs RMSNorm 技术对比
  • [学习]RTKLib详解:ionex.c、options.c与preceph.c
  • 【PostgreSQL数据分析实战:从数据清洗到可视化全流程】金融风控分析案例-10.1 风险数据清洗与特征工程
  • Python语言在地球科学交叉领域中的应用——从数据可视化到常见数据分析方法的使用【实例操作】
  • Spring MVC 根据请求头 (如 Accept) 怎么返回 JSON 或 XML 数据?
  • 破解 Qt QProcess 在 Release 模式下的“卡死”之谜
  • 多模态大语言模型arxiv论文略读(七十一)
  • 基于Spring AI实现多轮对话系统架构设计
  • PHP 代理服务器:如何在 PHP 中设置代理
  • 热门CPS联盟小程序聚合平台与CPA推广系统开发搭建:助力流量变现与用户增长
  • Android Studio的jks文件
  • DDR的PCB设计(T点)
  • 力扣210(拓扑排序)
  • 1. 使用 IntelliJ IDEA 创建 React 项目:创建 React 项目界面详解;配置 Yarn 为包管理器
  • VLM-RL:用于安全自动驾驶的统一视觉语言模型和强化学习框架——论文阅读
  • vue3搭建实战项目笔记四
  • 前端面试高频50个问题,解答
  • 【2025最新】Vm虚拟机中直接使用Ubuntu 免安装过程直接使用教程与下载