Docker 环境下的 Nginx 负载均衡(vllm)

背景

在linux上实现负载均衡,我在其他服务器上四个vllm的端口,端口分别时8001/v1,8002/v1,8003/v1,8004/v1,需要配置一个监听,使用9000端口,对四个端口进行转发,同时某些端口有时可能不能访问。

在 Ubuntu 上使用 Docker 实现负载均衡,最稳妥且高效的方案是使用 Nginx。Nginx 的 upstream 模块专门用于分发流量,并且内置了基础的健康检查机制(当某个后端端口不可用时,它会自动重试其他端口并暂时剔除不可用节点)。

准备目录结构

bash 复制代码
mkdir nginx-lb && cd nginx-lb
touch docker-compose.yml
touch nginx.conf

配置 Nginx 负载均衡策略

bash 复制代码
events {
    worker_connections 2048;
}

http {
    client_max_body_size 100m;
    # 基础日志格式定义
    log_format main '$remote_addr - $remote_user [$time_local] "$request" '
                    '$status $body_bytes_sent "$http_referer" '
                    '"$http_user_agent" "$upstream_addr" $request_time';

    access_log /var/log/nginx/access.log main;
    error_log /var/log/nginx/error.log warn;

    upstream vllm_servers {
        # 进阶点 1:最少连接算法。LLM 推理时间差异很大,
        # 将新请求发给当前正在处理请求最少的后端,比轮询更科学。
        least_conn;

        server 127.0.0.1:8001 max_fails=2 fail_timeout=30s;
        server 127.0.0.1:8002 max_fails=2 fail_timeout=30s;
        server 127.0.0.1:8003 max_fails=2 fail_timeout=30s;
        server 127.0.0.1:8004 max_fails=2 fail_timeout=30s;

        # 进阶点 2:保持与后端的长连接,减少 TCP 握手开销
        keepalive 32;
    }

    server {
        listen 9000;

        location / {
            proxy_pass http://vllm_servers;

            # 进阶点 3:禁用缓冲 (关键!)。
            # vLLM 通常使用流式输出 (Stream),开启缓冲会导致内容攒够了一大块才显示。
            proxy_buffering off;
            proxy_cache off;
            
            # 设置长连接头
            proxy_http_version 1.1;
            proxy_set_header Connection "";
            
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

            # 超时控制:LLM 生成可能很慢,给够 10 分钟
            proxy_read_timeout 600s;
            proxy_connect_timeout 10s;

            # 容错:当其中一个端口返回错误或超时,自动切换到下一个
            proxy_next_upstream error timeout http_500 http_502 http_503 http_504;
        }

        # 状态监控页面 (可选)
        # 访问 http://IP:9000/nginx_status 可以看到当前连接数
        location /nginx_status {
            stub_status on;
            allow 127.0.0.1; # 安全起见,只允许特定 IP 访问或干脆注释掉
            # allow 你的管理IP;
            # deny all;
        }
    }
}

配置docker-compose.yml

bash 复制代码
services:
  vllm-proxy:
    image: nginx:alpine  # 使用更轻量级的 alpine 版本
    container_name: vllm-load-balancer
    restart: unless-stopped
    ports:
      - "9000:9000"
    volumes:
      - ./nginx.conf:/etc/nginx/nginx.conf:ro
      - ./logs:/var/log/nginx
    networks:
      - vllm-net
    # 限制容器资源,防止 Nginx 在极端流量下影响主机
    deploy:
      resources:
        limits:
          cpus: '0.5'
          memory: 512M

networks:
  vllm-net:
    driver: bridge

启动

在 vllm-lb 目录下执行

bash 复制代码
docker-compose up -d

热重载

bash 复制代码
docker exec vllm-load-balancer nginx -s reload

查看状态

bash 复制代码
docker logs -f vllm-load-balancer

查看配置是否正确

bash 复制代码
docker exec vllm-load-balancer cat /etc/nginx/nginx.conf

关闭

bash 复制代码
docker-compose down
相关推荐
NGINX开源社区4 小时前
NGINX 与 Avi:云端性能之比较
nginx·反向代理
C_心欲无痕14 小时前
nginx - 实现域名跳转的几种方式
运维·前端·nginx
令狐少侠201118 小时前
docker基本操作 部署启动nginx
nginx·docker·容器
知南x18 小时前
【物联网视频监控系统----韦东山老师视频总结】(4)流媒体方案的实现之Nginx
物联网·nginx·音视频
成为你的宁宁1 天前
【Zabbix运维监控实战(附图文教程):Nginx 服务可用性、连接请求状态、CPU 内存占用与 JVM(Jar 包 / Tomcat)全维度监控】
运维·jvm·nginx·zabbix
实战项目1 天前
集群负载均衡关键技术研究
运维·负载均衡
oMcLin1 天前
如何在 Debian 11 上配置并调优 Nginx 与 Lua 脚本,提升高流量 API 网关的性能与安全性?
nginx·debian·lua
oMcLin1 天前
如何在CentOS 8.4上配置并优化Nginx负载均衡,确保跨境电商平台的高并发请求稳定处理?
nginx·centos·负载均衡
国强_dev1 天前
LVS 负载均衡核心原理深度剖析:从 NAT 到 DR 模式详解
运维·负载均衡·lvs