nginx:负载均衡

目录

一、最基础负载均衡(轮询)

[二、4 种常用负载均衡策略](#二、4 种常用负载均衡策略)

1)权重轮询(性能不同机器用)

[2)IP 哈希(同一个 IP 永远访问同一台](#2)IP 哈希(同一个 IP 永远访问同一台)

3)最少连接(least_conn)

[4)URL 哈希(同一个接口 / 资源固定一台)](#4)URL 哈希(同一个接口 / 资源固定一台))

三、高可用配置(宕机自动剔除)


一、最基础负载均衡(轮询)

nginx.confhttp 块内 加一个 upstream,然后在 location 里 proxy_pass 指向它。

XML 复制代码
http {

    # 1. 定义负载均衡池(名字随便起,比如 backend_servers)
    upstream backend_servers {
        server 127.0.0.1:8080;  # 后端服务1
        server 127.0.0.1:8081;  # 后端服务2
        server 127.0.0.1:8082;  # 后端服务3
    }

    server {
        listen 80;
        server_name localhost;

        location /api/ {
            # 2. 代理到 upstream 名字
            proxy_pass http://backend_servers;

            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header X-Forwarded-Proto $scheme;
        }
    }
}

默认策略:**轮询(round-robin)**请求依次分给:8080 → 8081 → 8082 → 8080...

二、4 种常用负载均衡策略

1)权重轮询(性能不同机器用)
XML 复制代码
upstream backend_servers {
    server 127.0.0.1:8080 weight=3;  # 访问3次
    server 127.0.0.1:8081 weight=2;  # 访问2次
    server 127.0.0.1:8082 weight=1;  # 访问1次
}
2)IP 哈希(同一个 IP 永远访问同一台

适合:登录会话、Session 不共享

XML 复制代码
upstream backend_servers {
    ip_hash;
    server 127.0.0.1:8080;
    server 127.0.0.1:8081;
}
3)最少连接(least_conn)

分给连接数最少的机器

XML 复制代码
upstream backend_servers {
    least_conn;
    server 127.0.0.1:8080;
    server 127.0.0.1:8081;
}
4)URL 哈希(同一个接口 / 资源固定一台)
XML 复制代码
upstream backend_servers {
    hash $request_uri;
    server 127.0.0.1:8080;
    server 127.0.0.1:8081;
}

三、高可用配置(宕机自动剔除)

加上 max_fails、fail_timeout,机器挂了自动踢走,恢复后自动加回:

XML 复制代码
upstream backend_servers {
    server 127.0.0.1:8080 max_fails=3 fail_timeout=30s;
    server 127.0.0.1:8081 max_fails=3 fail_timeout=30s;
    server 127.0.0.1:8082 backup;  # 备用机,其他全挂才启用
}

参考文献:豆包

相关推荐
Yang961140 分钟前
12 小时续航 + 1.5kg 便携!鼎讯信通 OTDR 适配复杂野外运维
运维·网络
身如柳絮随风扬41 分钟前
Nginx 核心配置与实战解析:从入门到进阶
运维·nginx
xiaoduo AI1 小时前
智能客服机器人能精准预判用户疑问提前主动应答吗?能大幅缩短客户咨询沟通时长吗?
运维·服务器·机器人
勤劳的进取家1 小时前
服务器文件交互方式
运维·服务器·microsoft
yyuuuzz1 小时前
aws亚马逊云上部署常见问题梳理
运维·服务器·网络·数据库·云计算·aws
优化Henry1 小时前
5G站点光链路降级告警排查与处理——AAS光端口隐性故障定位
运维·网络·5g·信息与通信
wanhengidc2 小时前
算力服务器的优势都有哪些?
大数据·运维·服务器·网络·人工智能·安全·智能手机
bukeyiwanshui2 小时前
20260508 docker教案
运维·docker·容器
King's King2 小时前
自动化立体仓库项目立项申请报告
运维·自动化
xingyuzhisuan2 小时前
风冷还是水冷?RTX 4090服务器散热方案对比
运维·服务器·ai·gpu算力