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

参考文献:豆包

相关推荐
爱莉希雅&&&3 小时前
Docker 部署 MySQL 双主双从同步架构详细笔记
linux·运维·数据库·mysql·docker·架构·主从同步
Alex艾力的IT数字空间10 小时前
在 Kylin(麒麟)操作系统上搭建 Docker 环境
大数据·运维·缓存·docker·容器·负载均衡·kylin
陳103010 小时前
Linux:进程间切换与调度
linux·运维·服务器
邂逅星河浪漫12 小时前
【银行内网开发-管理端】Vue管理端+Auth后台开发+Nginx配置+Linux部署(详细解析)
linux·javascript·css·vue.js·nginx·html·前后端联调
SilentSamsara13 小时前
TCP 三次握手:连接建立失败的那些坑
运维·服务器·网络·网络协议·tcp/ip
code tsunami14 小时前
如何在车辆数据自动化中解决Cloudflare Turnstile
运维·microsoft·自动化
翼龙云_cloud15 小时前
亚马逊云代理商:CloudWatch Agent 全解析 5 步实现服务器监控
运维·服务器·云计算·aws·云服务器
Cyber4K15 小时前
【Nginx专项】基础入门篇:状态页、微更新、内容替换、读取、压缩及防盗链
linux·运维·服务器·nginx·github
awei091616 小时前
MinIO配置自定义crossdomain.xml跨域策略(Nginx反向代理实现)
xml·java·nginx