Nginx 反代与 WebSocket 常见坑排查清单

这篇是工程型排障清单:遇到 WS 连不上时按这个顺序查,基本能定位到问题点。

先给结论

WebSocket 不通,99% 不是"框架坏了",而是以下三类问题:

  1. 路径错了 / 被路由接管
  2. Upgrade 头没传进去
  3. 权限或跨域拦截

一、排查顺序(强烈建议按这个来)

  1. 确认访问路径是否命中后端
  2. 确认 Nginx 是否走了 WebSocket location
  3. 确认 Upgrade/Connection 头是否正确
  4. 确认后端握手是否返回 101
  5. 确认权限/登录态是否带上

二、最稳的 Nginx WebSocket 配置模板

nginx 复制代码
map $http_upgrade $connection_upgrade {
    default upgrade;
    '' close;
}

location /ws/ {
    proxy_pass http://127.0.0.1:8123/ws/;
    proxy_http_version 1.1;
    proxy_set_header Upgrade $http_upgrade;
    proxy_set_header Connection $connection_upgrade;
    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_read_timeout 3600s;
    proxy_send_timeout 3600s;
    proxy_buffering off;
}

三、最常见的 6 个坑

1) location 被 /api/ 抢走

如果 WebSocket 路径是 /api/ws/...,必须有专用 location:

nginx 复制代码
location /api/ws/ { ... }

并且放在 /api/ 前面。


2) proxy_pass 路径写错

复制代码
location /api/ws/ {
    proxy_pass http://127.0.0.1:8123/ws/;
}

上面会把 /api/ws/xxx 改成 /ws/xxx,后端 404。

正确写法:

复制代码
proxy_pass http://127.0.0.1:8123;

3) 没有 Upgrade 头

没有这两行基本没戏:

复制代码
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection $connection_upgrade;

WebSocket 也是握手 HTTP,如果依赖登录态:

  • 要保证 Cookie 能带上
  • 或直接 query 传 token

5) 后端返回 404/500

如果后端直接 404,说明路径没命中。

如果后端 500,多半是拦截器/权限校验失败。


6) http 与 https 混用

主站是 https 时,WebSocket 必须用 wss://

否则浏览器会直接拦截。


四、快速自检命令

bash 复制代码
curl -i -N \
  -H "Connection: Upgrade" \
  -H "Upgrade: websocket" \
  "http://127.0.0.1:8123/ws/app/edit"

看到 101 Switching Protocols 才算后端 OK。


最后总结

排 WebSocket 先别猜,按"路径 → 头 → 状态码"三步走,

基本能在 5 分钟内定位问题。

相关推荐
Avan_菜菜6 天前
FRP 内网穿透完整实战:从 HTTP 映射到 HTTPS 自签代理
运维·nginx·https
ping某10 天前
为什么 Nginx 明明监听了 80,转发后端时却用了 4xxxx 端口?
后端·nginx
難釋懷12 天前
Nginx反向代理中的容错机制
运维·nginx
bloglin9999912 天前
Nginx高危漏洞CVE-2021-23017及配置样例
运维·nginx
进阶的小名12 天前
Spring Boot SSE + Nginx 配置:解决 EventSource 不实时返回、连接超时、流式响应被缓冲问题
spring boot·后端·nginx
難釋懷12 天前
Nginx获取客户端真实IP
服务器·前端·nginx
qq_谁赞成_谁反对12 天前
甲方IT的成长之路--nginx实战--2604
服务器·数据库·nginx
七夜zippoe12 天前
DolphinDB WebSocket接入:实时数据流
网络·websocket·网络协议·dolphindb·实时数据流
图灵追慕者12 天前
Nginx安裝以及配置顯示本地服務器文件夾
运维·nginx
于先生吖13 天前
从零搭建Java萌宠社交系统:WebSocket实时聊天+动态发布模块实现
java·开发语言·websocket