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

参考文献:豆包

相关推荐
XIAOHEZIcode8 小时前
Linux系统鼠标偏移常见原因以及修复方案
linux·运维·游戏
用户0328472220701 天前
如何搭建本地yum源(上)
运维
ping某2 天前
为什么 Nginx 明明监听了 80,转发后端时却用了 4xxxx 端口?
后端·nginx
大树884 天前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
摇滚侠4 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
霸道流氓气质4 天前
领域驱动设计(DDD)在 Spring Boot 微服务中的实践指南
运维·spring boot·微服务
Inhand陈工4 天前
基于台达PLC与映翰通IG502的智慧水产养殖精准投喂与远程运维解决方案
运维·人工智能·物联网·阿里云·信息与通信
酣大智4 天前
ARP代理--工作原理
运维·网络·arp·arp代理
shushangyun_4 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
施努卡机器视觉4 天前
SNK施努卡侧滑门锁上滑轮总成自动化装配线,从零件到组件,全流程精密制造方案
运维·自动化·制造