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

nginx负载均衡模式

轮询 (Round Robin)

用法:这是Nginx默认的负载均衡策略。每个请求会按顺序分配给upstream中的后端服务器,即按照配置的服务器列表顺序依次分配。

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

加权轮询 (Weighted Round Robin)

用法:可以根据服务器的不同处理能力,通过权重设置分配请求的比例。

   upstream backend {server backend1.example.com weight=1;server backend2.example.com weight=2;server backend3.example.com;}

IP哈希 (ip_hash)

用法:根据客户端IP地址的哈希值进行负载均衡,确保同一客户端的请求总是被转发到同一台后端服务器,这有助于维持用户会话的连续性。

   upstream backend {ip_hash;server backend1.example.com;server backend2.example.com;server backend3.example.com;}

URL哈希 (url_hash 或 hash)

用法:基于请求的URL进行哈希计算,将相同URL的请求定向到同一台服务器上,适用于缓存场景或保持特定URL访问的一致性。

   upstream backend {hash $request_uri;server backend1.example.com;server backend2.example.com;server backend3.example.com;}

fair(第三方模块)

用法:基于后端服务器的响应时间动态分配请求,优先分配给之前响应时间最短的服务器,以实现更公平的负载均衡。

   # 需要安装第三方nginx_upstream_fair模块upstream backend {fair;server backend1.example.com;server backend2.example.com;server backend3.example.com;}

最少连接数(Least Connections)

用法:自动将请求分配给当前连接数最少的服务器,避免某台服务器过载

   # 标准版Nginx不支持直接配置least_conn,但可以通过第三方模块实现# 若使用官方支持的版本,则可以直接使用:upstream backend {least_conn;server backend1.example.com;server backend2.example.com;server backend3.example.com;}

最少连接数 (Least Connections): 这种模式下,Nginx会将新的请求分配给当前连接数最少的服务器,这样可以保证那些已经处理较少请求的服务器获得更多的新连接,从而在一定程度上平衡各个服务器的负载。若某个节点出现故障导致连接堆积,理论上它会被分配到的请求减少。
健康检查 (Health Checks): Nginx本身并未内置完整的健康检查功能,但可以通过第三方模块如 ngx_http_upstream_check_module 或结合使用HTTP 500错误返回或其他机制实现健康检查。通过配置健康检查,Nginx可以定期向后端服务器发送请求以检测其是否可用。如果服务器无响应或者响应不符合预期,Nginx可以将其标记为不可用,并停止向该服务器发送新的请求,直到其恢复可用状态。

upstream backend {server backend1.example.com max_fails=3 fail_timeout=30s;server backend2.example.com max_fails=3 fail_timeout=30s;server backend3.example.com max_fails=3 fail_timeout=30s;# 如果结合第三方健康检查模块,启用检查# check interval=3000 rise=2 fall=5;
}
http://www.lryc.cn/news/329235.html

相关文章:

  • 手写简易操作系统(十七)--编写键盘驱动
  • springboot中基于RestTemplate 类 实现调用第三方API接口【POST版本】
  • 编程器固件修改教程
  • Python从原Excel表中抽出数据存入同一文件的新的Sheet(附源码)
  • 计算机网络实验六:路由信息协议RIP
  • MySQL数据库备份策略与实践详解
  • String类相关oj练习
  • 【Linux】进程实践项目 —— 自主shell编写
  • 基于SpringBoot和Vue的学生笔记共享平台的设计与实现
  • C++心决之命名空间、重载函数和引用
  • higress使用了解
  • Swagger3探索之游龙入海
  • javaWeb项目-学生考勤管理系统功能介绍
  • 云备份项目认识、环境搭建以及所使用的库的介绍
  • 汇编语言第四版-王爽第2章 寄存器
  • MoonBit MeetUp回顾——张正、宗喆:编程语言在云原生与区块链领域的技术探索
  • 云原生靶场kebernetesGoat、Metarget
  • 【3D目标检测】Det3d—SE-SSD模型训练(前篇):KITTI数据集训练
  • k8s1.28.8版本安装prometheus并持久化数据
  • Mybatis-特殊SQL的执行
  • 金融衍生品市场
  • 2、Cocos Creator 下载安装
  • Docker版本:18.06.1安装
  • 记 SpringBoot 使用@RequestBody 接收不到参数
  • unity 打包安卓错误汇集
  • C语言-文件操作
  • ADB 操作命令详解及用法大全
  • 指针数组。
  • GitHub开源项目权限管理-使用账号和个人令牌访问
  • DevSecOps平台架构系列-亚马逊云AWS DevSecOps平台架构