Nginx几种负载均衡模式的实现示例

 更新时间:2025年10月31日 08:20:33   作者:就叫飞六吧  
本文主要介绍了Nginx几种负载均衡模式的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

1.轮询 (Round Robin) - 默认模式

按顺序逐一分配请求到各个后端服务器。

upstream backend {
    server 192.168.1.10;
    server 192.168.1.11;
    server 192.168.1.12;
}

2.加权轮询 (Weighted Round Robin)

根据权重分配请求,权重越高,被分配的请求越多。

upstream backend {
    server 192.168.1.10 weight=3;
    server 192.168.1.11 weight=2;
    server 192.168.1.12 weight=1;
}

3.IP 哈希 (IP Hash)

根据客户端 IP 地址进行哈希计算,同一 IP 的请求会被分配到同一台服务器,可以解决 session 共享问题。

upstream backend {
    ip_hash;
    server 192.168.1.10;
    server 192.168.1.11;
    server 192.168.1.12;
}

4.最少连接 (Least Connections)

将请求分配给当前连接数最少的服务器。

upstream backend {
    least_conn;
    server 192.168.1.10;
    server 192.168.1.11;
    server 192.168.1.12;
}

5.一致性哈希 (Consistent Hash)

需要第三方模块支持,根据指定的 key 进行哈希分配。

upstream backend {
    hash $request_uri consistent;
    server 192.168.1.10;
    server 192.168.1.11;
    server 192.168.1.12;
}

6.通用哈希 (Generic Hash)

可以基于任意变量进行哈希。

upstream backend {
    hash $remote_addr;  # 基于客户端IP
    # hash $cookie_jsessionid;  # 基于cookie
    server 192.168.1.10;
    server 192.168.1.11;
}

7.随机 (Random)

随机选择一台服务器(Nginx 1.15.1+ 版本支持)。

upstream backend {
    random;
    server 192.168.1.10;
    server 192.168.1.11;
    server 192.168.1.12;
}

常用参数配置

upstream backend {
    server 192.168.1.10 weight=5 max_fails=3 fail_timeout=30s;
    server 192.168.1.11 weight=3;
    server 192.168.1.12 backup;  # 备用服务器
    server 192.168.1.13 down;    # 标记为不可用
}

参数说明:

  • weight: 权重,默认为 1
  • max_fails: 允许请求失败的次数,默认为 1
  • fail_timeout: 失败超时时间,默认为 10 秒
  • backup: 备份服务器,只有其他服务器都不可用时才使用
  • down: 标记服务器永久不可用

最常用的模式:

  • 无状态应用:轮询、加权轮询、最少连接
  • 有状态应用:IP Hash、一致性哈希

到此这篇关于Nginx几种负载均衡模式的实现示例的文章就介绍到这了,更多相关Nginx 负载均衡模式内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Nginx的一些基本功能极速入门

    Nginx的一些基本功能极速入门

    本文主要介绍一些Nginx的最基本功能以及简单配置,但不包括Nginx的安装部署以及实现原理。有兴趣的可以了解一下。
    2016-12-12
  • nginx版本热更新实现过程

    nginx版本热更新实现过程

    这篇文章主要介绍了nginx版本热更新实现过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-07-07
  • 提升Nginx性能的一些建议

    提升Nginx性能的一些建议

    这篇文章主要介绍了提升Nginx性能的一些建议,帮助大家更好的使用nginx,感兴趣的朋友可以了解下
    2020-09-09
  • centos系统下LNMP环境一键安装

    centos系统下LNMP环境一键安装

    centos下的LNMP环境一键安装实现方法,需要的朋友可以参考下。
    2010-06-06
  • 使用nginx打包部署前端vue项目完整过程(保姆级教程)

    使用nginx打包部署前端vue项目完整过程(保姆级教程)

    这篇文章主要给大家介绍了关于使用nginx打包部署前端vue项目的相关资料,包括打包命名、执行打包命令、检查打包成功、下载和解压Nginx、部署到Nginx、启动Nginx并访问项目、以及Nginx的优势,需要的朋友可以参考下
    2024-11-11
  • Nginx配置文件详解

    Nginx配置文件详解

    这篇文章主要介绍了Nginx配置文件详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • Linux服务器下nginx的安全配置详解

    Linux服务器下nginx的安全配置详解

    本篇文章主要介绍了Linux服务器下nginx的安全配置详解,Nginx在很多高流量网站上得到了应用,有需要的朋友可了解一下。
    2016-10-10
  • Nginx的基本概念和原理

    Nginx的基本概念和原理

    这篇文章主要介绍了Nginx的基本概念和原理,Nginx专为性能优化而开发,性能是器最重要的考量,实现上非常注重效率,能经受高负载的考验,据报告能支持高达50,000个并发连接数。下文我们就来看看Nginx概念和原理,需要的小伙伴可以参考一下
    2022-03-03
  • windows查看nginx是否启动的四种方法

    windows查看nginx是否启动的四种方法

    本文主要介绍了windows查看nginx是否启动的两种方法,文中通过图文代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-07-07
  • Node.js站点使用Nginx作反向代理时配置GZip压缩的教程

    Node.js站点使用Nginx作反向代理时配置GZip压缩的教程

    这篇文章主要介绍了Node.js站点使用Nginx作反向代理时配置GZip压缩的教程,文中演示了Node使用Express框架时的HTTP传输压缩配置,需要的朋友可以参考下
    2016-04-04

最新评论