news 2026/4/17 11:33:07

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Docker 环境下的 Nginx 负载均衡(vllm)

背景

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

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

准备目录结构

mkdirnginx-lb&&cdnginx-lbtouchdocker-compose.ymltouchnginx.conf

配置 Nginx 负载均衡策略

events{worker_connections2048;}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;server127.0.0.1:8001max_fails=2fail_timeout=30s;server127.0.0.1:8002max_fails=2fail_timeout=30s;server127.0.0.1:8003max_fails=2fail_timeout=30s;server127.0.0.1:8004max_fails=2fail_timeout=30s;# 进阶点 2:保持与后端的长连接,减少 TCP 握手开销keepalive32;}server{listen9000;location /{proxy_pass http://vllm_servers;# 进阶点 3:禁用缓冲 (关键!)。# vLLM 通常使用流式输出 (Stream),开启缓冲会导致内容攒够了一大块才显示。proxy_buffering off;proxy_cache off;# 设置长连接头proxy_http_version1.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 errortimeouthttp_500 http_502 http_503 http_504;}# 状态监控页面 (可选)# 访问 http://IP:9000/nginx_status 可以看到当前连接数location /nginx_status{stub_status on;allow127.0.0.1;# 安全起见,只允许特定 IP 访问或干脆注释掉# allow 你的管理IP;# deny all;}}}

配置docker-compose.yml

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 目录下执行

docker-composeup -d

热重载

dockerexecvllm-load-balancer nginx -s reload

查看状态

dockerlogs -f vllm-load-balancer

查看配置是否正确

dockerexecvllm-load-balancercat/etc/nginx/nginx.conf

关闭

docker-composedown
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/17 0:23:40

基于SpringBoot与微信小程序的粤语文化传播平台设计与实现

一、系统开发背景与需求分析 粤语作为中国重要的方言之一,承载着岭南地区深厚的历史文化,但当前面临传承断层风险。年轻一代使用频率下降,传统传播方式(如电视节目、线下活动)覆盖范围有限,且缺乏互动性。微…

作者头像 李华
网站建设 2026/4/8 21:59:02

研究领域最新的文献怎么找:实用方法与高效检索技巧指南

刚开始做科研的时候,我一直以为: 文献检索就是在知网、Google Scholar 里反复换关键词。 直到后来才意识到,真正消耗精力的不是“搜不到”,而是—— 你根本不知道最近这个领域发生了什么。 生成式 AI 出现之后,学术检…

作者头像 李华
网站建设 2026/4/11 13:01:34

导师推荐!专科生必备!8款AI论文平台测评TOP8

导师推荐!专科生必备!8款AI论文平台测评TOP8 2026年专科生论文写作工具测评:选对平台,事半功倍 随着AI技术在学术领域的广泛应用,越来越多的专科生开始借助AI论文平台提升写作效率与质量。然而,面对市场上琳…

作者头像 李华
网站建设 2026/4/17 7:40:33

JDK17 前后写法对比:差点没认出是 Java

Java,一直被开发者戏称为“啰嗦”,但从 JDK 12 到 JDK 17,这门语言发生了显著变化。多个语法层面的增强让 Java 更加简洁、表达力更强,也更接近现代语言的风格。本文将带你梳理这六个版本中 Java 的关键语法演进。👀语…

作者头像 李华
网站建设 2026/4/17 0:04:10

XHEDITOR前端如何兼容Word公式跨浏览器粘贴?

山西PHP程序员的逆袭之路:用代码搞钱,用QQ群发家! 各位老铁们好!我是老张,一个在山西太原窝着写PHP的"码农"。最近接了个CMS企业官网的外包项目,客户提出了个"变态"需求:要…

作者头像 李华
网站建设 2026/4/17 1:23:38

亲测好用!10款AI论文平台测评:研究生开题报告神器

亲测好用!10款AI论文平台测评:研究生开题报告神器 2026年AI论文平台测评:为何值得一看 在当前学术研究日益数字化的背景下,AI论文平台已成为研究生群体不可或缺的辅助工具。然而,面对市场上众多功能相似的产品&#xf…

作者头像 李华