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

在Nginx的stream模块中,upstream的权重配置实现的是连接级别的负载均衡 ,这和http模块不同。

当客户端发起一个新的TCP连接时,Nginx根据各upstream的权重值选择其中一个upstream建立连接,之后该连接上的所有数据传输都由这个upstream处理。


核心机制

  1. 连接级别的负载均衡

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

    • 权重(weight)决定了后端服务器接收新连接的比例 。例如:

      nginx 复制代码
      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模块的负载均衡功能。
相关推荐
三坛海会大神55511 小时前
LVS与Keepalived详解(二)LVS负载均衡实现实操
linux·负载均衡·lvs
qq_2642208911 小时前
LVS负载均衡群集和LVS+Keepalived群集
运维·负载均衡·lvs
雨落Liy12 小时前
Nginx 从入门到进阶:反向代理、负载均衡与高性能实战指南
运维·nginx·负载均衡
Yyyy48212 小时前
Nginx负载均衡集群实验步骤
运维·nginx·负载均衡
qq_264220891 天前
Nginx优化与 SSL/TLS配置
运维·nginx
matlab的学徒1 天前
Web与Nginx网站服务(改)
linux·运维·前端·nginx·tomcat
✎﹏赤子·墨筱晗♪1 天前
深入浅出LVS负载均衡群集:原理、分类与NAT模式实战部署
分类·负载均衡·lvs
邂逅星河浪漫1 天前
【Docker+Nginx+Ollama】前后端分离式项目部署(传统打包方式)
java·nginx·docker·部署
東雪蓮☆1 天前
LVS 负载均衡群集
linux·运维·服务器·负载均衡·lvs
IT成长日记1 天前
【Nginx开荒攻略】Nginx主配置文件结构与核心模块详解:从0到1掌握nginx.conf:
linux·运维·nginx·配置文件