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;  # 备用机,其他全挂才启用
}

参考文献:豆包

相关推荐
Plastic garden8 分钟前
Docker(1)
运维·docker·容器
s_w.h20 分钟前
【 linux 】动静态库的制作
linux·运维·服务器·算法·bash
songjxin24 分钟前
Nginx 日志分析可视化面板
运维·nginx
专注VB编程开发20年1 小时前
安卓APP与服务器通讯技术,文件传输和文字消息收发
运维·服务器
Agent手记1 小时前
电信运营商如何用AI实现携号转网自动处理?基于实在Agent的业务自动化落地与TARS大模型解析方案
运维·人工智能·ai·自动化
wanhengidc2 小时前
云手机搬砖 像僵尸开炮
运维·网络·智能手机·云计算
_Voosk2 小时前
FreeBSD 使用代理运行命令
linux·运维·freebsd
lihui_cbdd2 小时前
HPC 集群上 OpenMM GPU 多版本安装实战指南
运维·服务器·人工智能·计算化学
志栋智能3 小时前
超越监控:超自动化巡检提供的主动价值
运维·网络·人工智能·自动化
java_logo3 小时前
2026 Docker 国内镜像加速配置教程
运维·docker·容器·docker镜像·docker镜像源·docker镜像加速·docker镜像国内库