本文详细介绍关于Nginx 配置负载均衡,包括配置文件结构、多种负载均衡策略、如何修改均衡策略以及其他一些重要的配置。
本文目录
-
- 一、、Nginx 配置负载均衡
-
- 1. 配置文件结构
- 二、Nginx 负载均衡策略
-
- 1. 轮询(`默认策略`)
- 2. 加权轮询
- 3. IP 哈希
- 4. 最少连接
- 1. 轮询(`默认策略`)
- 三、修改负载均衡策略
- 四、Nginx 负载均衡其他配置
-
- 1. 健康检查
- 2. 会话保持
- 3. 超时设置
- 1. 健康检查
一、、Nginx 配置负载均衡
1. 配置文件结构
Nginx 的负载均衡配置主要在 http 块内的 upstream 指令和 server 块内的 proxy_pass 指令中完成。
配置示例如下:
1http { 2 upstream backend_servers { # 后端服务器组 3 server 192.168.1.100:8080; 4 server 192.168.1.101:8080; 5 } 6 7 server { 8 listen 80; 9 server_name ecommerce.com; 10 11 location / { 12 proxy_pass http://backend_servers; # 将客户端的请求转发到指定的后端服务器组 13 proxy_set_header Host $host; 14 proxy_set_header X - Real - IP $remote_addr; # 设置请求头信息,确保后端服务器能获取客户端的真实信息。 15 } 16 } 17} 18
二、Nginx 负载均衡策略
1. 轮询(默认策略)
Nginx 按照顺序依次将请求分发到后端服务器,每个服务器轮流处理请求。例如,第一个请求发送到 192.168.1.100:8080,第二个请求发送到 192.168.1.101:8080,以此类推。
1upstream backend_servers { 2 server 192.168.1.100:8080; 3 server 192.168.1.101:8080; 4} 5
2. 加权轮询
为每个后端服务器分配一个权重,权重越高的服务器处理的请求越多。在系统中,如果某台服务器的性能较好,可以为其分配较高的权重。
1upstream backend_servers { 2 server 192.168.1.100:8080 weight=2; 3 server 192.168.1.101:8080 weight=1; 4} 5
3. IP 哈希
根据客户端的 IP 地址进行哈希计算,将相同 IP 地址的请求总是发送到同一台后端服务器。这种策略适用于需要保持会话状态的场景,如系统中的用户登录状态。
1upstream backend_servers { 2 ip_hash; 3 server 192.168.1.100:8080; 4 server 192.168.1.101:8080; 5} 6
4. 最少连接
将请求发送到当前连接数最少的后端服务器,以确保各服务器的负载相对均衡。
1upstream backend_servers { 2 least_conn; 3 server 192.168.1.100:8080; 4 server 192.168.1.101:8080; 5} 6
三、修改负载均衡策略
如果需要修改负载均衡策略,只需在 upstream 块中修改相应的指令。
将轮询策略改为加权轮询:
1upstream backend_servers { 2 # 原轮询策略 3 # server 192.168.1.100:8080; 4 # server 192.168.1.101:8080; 5 6 # 修改为加权轮询策略 7 server 192.168.1.100:8080 weight=3; 8 server 192.168.1.101:8080 weight=1; 9} 10
修改完成后,需要重新加载 Nginx 配置文件:
1sudo nginx -s reload 2
四、Nginx 负载均衡其他配置
1. 健康检查
可以通过 server 指令的 max_fails 和 fail_timeout 参数进行健康检查。当后端服务器在 fail_timeout 时间内出现 max_fails 次失败请求时,Nginx 会认为该服务器不可用,暂时不再向其发送请求。
1upstream backend_servers { 2 server 192.168.1.100:8080 max_fails=3 fail_timeout=10s; 3 server 192.168.1.101:8080 max_fails=3 fail_timeout=10s; 4} 5
2. 会话保持
在需要保持会话状态的系统中,可以使用 sticky 模块实现会话保持。例如,使用 sticky cookie 方式:
1upstream backend_servers { 2 sticky cookie srv_id expires=1h domain=ecommerce.com path=/; 3 server 192.168.1.100:8080; 4 server 192.168.1.101:8080; 5} 6
3. 超时设置
可以通过 proxy_connect_timeout、proxy_send_timeout 和 proxy_read_timeout 等指令设置连接超时、发送超时和读取超时时间,避免长时间等待无响应的后端服务器。
1server { 2 listen 80; 3 server_name ecommerce.example.com; 4 5 location / { 6 proxy_pass http://backend_servers; 7 proxy_connect_timeout 5s; 8 proxy_send_timeout 10s; 9 proxy_read_timeout 10s; 10 } 11} 12
| ← 上一篇 MySQL——表添加索引多种方式 | 记得点赞、关注、收藏哦! | 下一篇 JUC小册——公平锁和非公平锁 → |
|---|
《Nginx 配置负载均衡(详细版)》 是转载文章,点击查看原文。