Nginx负载均衡与故障转移实践

本文涉及的产品
无影云电脑个人版,1个月黄金款+200核时
资源编排,不限时长
无影云电脑企业版,4核8GB 120小时 1个月
简介: Nginx通过ngx_http_upstream_module模块实现负载均衡与故障转移,适用于多服务器环境。利用`upstream`与`server`指令定义后端服务器组,通过`proxy_pass`将请求代理至这些服务器,实现请求分发。Nginx还提供了多种负载均衡策略,如轮询、权重分配、IP哈希等,并支持自定义故障转移逻辑,确保系统稳定性和高可用性。示例配置展示了如何定义负载均衡设备及状态,并应用到具体server配置中。

利用 proxy_pass 可以将请求代理到后端服务器。之前的示例主要针对单台服务器进行配置,然而在实际应用中,我们经常需要将请求分发到多台服务器上来实现负载均衡和故障转移。Nginx 提供了 ngx_http_upstream_module 模块,能够为反向代理提供重要功能,如负载均衡和故障转移。

代理多台服务器

以下是一个简单的配置示例:

http {
    upstream backend {
        server 192.168.0.14;
        server 192.168.0.15;
    }

    server {
        listen 80;

        location / {
            proxy_pass http://backend;
        }
    }
}

指令详解

  • upstream:定义一组 HTTP 服务器,这些服务器可以监听不同的端口,也可以是 TCP 和 UNIX 套接字。可以混合使用不同的端口、 TCP 和 UNIX 套接字。
upstream name {...}
  • server:配置后端服务器,参数可以是不同的 IP 地址、端口号,甚至域名。其参数包括 IP 地址、端口号等。
server address [parameters];

故障转移

当某些后端服务器无法正常响应时,Nginx 提供了一些指令进行故障转移,如 proxy_next_upstream。

  • proxy_next_upstream:定义转发条件,当请求返回 Nginx 时,如果 HTTP 状态满足 proxy_next_upstream 设置的条件,会将请求重新转发到下一台后端服务器。
proxy_next_upstream error | timeout | invalid_header | http_500 | http_502 | http_503 | http_504 | http_403 | http_404 | http_429 | non_idempotent | off ...;
  • proxy_next_upstream_tries:定义尝试请求的次数,达到次数上限后停止转发。
proxy_next_upstream_tries number;
  • proxy_next_upstream_timeout:限制尝试请求的超时时间,若设置为 0 表示无超时时间。
proxy_next_upstream_timeout time;

负载均衡

Nginx 不仅支持代理多台后端服务器,还支持各种负载均衡模式,如轮询、权重、IP 哈希等。

  • 轮询(默认)

每个请求按时间顺序逐一分配到不同的后端服务器:

upstream backend {
    server 192.168.0.14;
    server 192.168.0.15;
}
  • weight

指定轮询几率,权重越大,负载的权重就越大:

upstream backend {
    server 192.168.0.14 weight=10;
    server 192.168.0.15 weight=10;
}
  • ip_hash

按访问 IP 的 hash 结果分配,每个访客固定访问一个后端服务器:

upstream backend {
    ip_hash;
    server 192.168.0.14:88;
    server 192.168.0.15:80;
}
  • fair(第三方模块)

按后端服务器的响应时间分配请求,响应时间短的优先分配:

upstream backend {
    server server1.example.com;
    server server2.example.com;
    fair;
}
  • least_conn(第三方模块)

请求分配给连接数较少的后端:

upstream backend {
    server server1.example.com;
    server server2.example.com;
    least_conn;
}
  • url_hash(第三方模块)

按访问 URL 的 hash 结果分配请求,使每个 URL 定向到同一个后端服务器:

upstream backend {
    server squid1:3128;
    server squid2:3128;
    hash $request_uri;
    hash_method crc32;
}

示例配置

# 定义负载均衡的设备及状态
upstream backend {
    ip_hash;
    server 127.0.0.1:9090 down;
    server 127.0.0.1:8080 weight=2;
    server 127.0.0.1:6060;
    server 127.0.0.1:7070 backup;
}

# 使用负载均衡的 server 配置
server {
    listen 80;

    location / {
        proxy_pass http://backend;
    }
}

负载均衡设备状态设置

  • down:该服务器暂时不参与负载均衡。
  • weight:权重,默认为1,权重越大,负载的权重就越大。
  • max_fails:允许请求失败的次数,超过最大次数时返回 proxy_next_upstream 模块定义的错误。
  • fail_timeout:max_fails 次失败后暂停的时间。
  • backup:其它所有非 backup 机器 down 或忙时,请求 backup 机器。

通过上述配置和指令,Nginx 可以在多台服务器之间高效地实现负载均衡和故障转移,从而提升系统的可靠性和性能。

相关文章
|
7天前
|
负载均衡 算法 搜索推荐
Nginx 常用的负载均衡算法
【10月更文挑战第17天】在实际应用中,我们需要根据具体的情况来选择合适的负载均衡算法。同时,还可以结合其他的优化措施,如服务器健康检查、动态调整权重等,来进一步提高负载均衡的效果和系统的稳定性。
|
19天前
|
负载均衡 应用服务中间件 Linux
nginx学习,看这一篇就够了:下载、安装。使用:正向代理、反向代理、负载均衡。常用命令和配置文件,很全
这篇博客文章详细介绍了Nginx的下载、安装、配置以及使用,包括正向代理、反向代理、负载均衡、动静分离等高级功能,并通过具体实例讲解了如何进行配置。
86 4
nginx学习,看这一篇就够了:下载、安装。使用:正向代理、反向代理、负载均衡。常用命令和配置文件,很全
|
3天前
|
负载均衡 算法 应用服务中间件
Nginx 常用的负载均衡算法
【10月更文挑战第22天】不同的负载均衡算法各有特点和适用场景。在实际应用中,需要根据具体的业务需求、服务器性能和网络环境等因素来选择合适的算法。
12 3
|
7天前
|
负载均衡 监控 应用服务中间件
除了 Nginx,还有以下一些常见的负载均衡工具
【10月更文挑战第17天】这些负载均衡工具各有特点和优势,在不同的应用场景中发挥着重要作用。选择合适的负载均衡工具需要综合考虑性能、功能、稳定性、成本等因素。
|
16天前
|
负载均衡 应用服务中间件 nginx
Nginx的6大负载均衡策略及权重轮询手写配置
【10月更文挑战第9天】 Nginx是一款高性能的HTTP服务器和反向代理服务器,它在处理大量并发请求时表现出色。Nginx的负载均衡功能可以将请求分发到多个服务器,提高网站的吞吐量和可靠性。以下是Nginx支持的6大负载均衡策略:
62 7
|
14天前
|
负载均衡 算法 Java
腾讯面试:说说6大Nginx负载均衡?手写一下权重轮询策略?
尼恩,一位资深架构师,分享了关于负载均衡及其策略的深入解析,特别是基于权重的负载均衡策略。文章不仅介绍了Nginx的五大负载均衡策略,如轮询、加权轮询、IP哈希、最少连接数等,还提供了手写加权轮询算法的Java实现示例。通过这些内容,尼恩帮助读者系统化理解负载均衡技术,提升面试竞争力,实现技术上的“肌肉展示”。此外,他还提供了丰富的技术资料和面试指导,助力求职者在大厂面试中脱颖而出。
腾讯面试:说说6大Nginx负载均衡?手写一下权重轮询策略?
|
17天前
|
缓存 负载均衡 算法
nginx学习:配置文件详解,负载均衡三种算法学习,上接nginx实操篇
Nginx 是一款高性能的 HTTP 和反向代理服务器,也是一个通用的 TCP/UDP 代理服务器,以及一个邮件代理服务器和通用的 HTTP 缓存服务器。
25 0
nginx学习:配置文件详解,负载均衡三种算法学习,上接nginx实操篇
|
JSON 监控 负载均衡
|
6天前
|
应用服务中间件 BI nginx
Nginx的location配置详解
【10月更文挑战第16天】Nginx的location配置详解
|
13天前
|
缓存 负载均衡 安全
Nginx常用基本配置总结:从入门到实战的全方位指南
Nginx常用基本配置总结:从入门到实战的全方位指南
179 0