【Websocket和nginx配置】

假设你的 Nginx 配置的目的是通过 8085 端口接受前端请求,前端请求有两类:

普通的 HTTP 请求(如页面加载、API 请求等)

WebSocket 请求(如实时通信)

这里有两个要点需要特别注意:

普通 HTTP 请求 需要正确转发给后端服务,同时确保支持 HTTP 的代理。
WebSocket 请求 需要特殊处理,因为 WebSocket 使用了 HTTP 协议进行连接升级(Upgrade 请求头)。
更新后的 Nginx 配置

nginx 复制代码
server {
    listen 8085;
    server_name localhost;

    # 处理普通的 HTTP 请求
    location / {
        proxy_pass http://localhost:8086;  # 将请求代理到后端的 HTTP 服务
        proxy_http_version 1.1;  # 必须指定 HTTP/1.1,WebSocket 也需要这个协议版本
        proxy_set_header Host $host;  # 保证后端能够获取到原始请求的 Host
        proxy_set_header X-Real-IP $remote_addr;  # 转发客户端的真实 IP
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;  # 转发客户端的真实 IP 链
        proxy_set_header X-Forwarded-Proto $scheme;  # 转发请求协议(http 或 https)
        proxy_cache_bypass $http_upgrade;  # 确保 WebSocket 不会缓存
    }

    # 处理 WebSocket 请求
    location /ws/ {  # 假设 WebSocket 请求路径为 /ws/
        proxy_pass http://localhost:8086;  # 将 WebSocket 请求代理到后端的 WebSocket 服务
        proxy_http_version 1.1;  # WebSocket 必须使用 HTTP/1.1
        proxy_set_header Upgrade $http_upgrade;  # WebSocket 握手需要 Upgrade 请求头
        proxy_set_header Connection 'upgrade';  # WebSocket 握手需要 Connection 为 upgrade
        proxy_set_header Host $host;  # 确保后端知道请求的主机名
        proxy_cache_bypass $http_upgrade;  # 禁止 WebSocket 请求被缓存
    }
}

解释和重点调整
location /: 这一部分负责处理普通的 HTTP 请求。只要路径不涉及 /ws/,所有请求都会匹配这个 location 规则。我们确保通过 proxy_pass 将请求代理到 localhost:8086(后端服务)。

  • proxy_http_version 1.1:这里设置 HTTP 版本为 1.1,这是为了支持 WebSocket 协议,同时确保代理时没有版本冲突。
  • proxy_set_header:这些代理头部帮助后端服务获取正确的请求信息(如 Host、客户端的真实 IP 地址等)。

location /ws/: 这一部分专门处理 WebSocket 请求。当请求路径以 /ws/ 开头时,Nginx 会将请求转发到后端的 8086 端口。

  • proxy_set_header Upgradeproxy_set_header Connection:这两项配置确保 WebSocket 握手时,Upgrade 和 Connection 请求头正确地传递,后端才会知道这是一条 WebSocket 请求。

总结

普通 HTTP 请求:这些请求会通过 / 匹配,并被转发到 localhost:8086。

WebSocket 请求:这些请求通过 /ws/ 匹配,并被正确地升级到 WebSocket 连接,代理到后端的 WebSocket 服务。

这样的配置可以同时处理普通的 HTTP 请求和 WebSocket 请求,并根据不同的路径(例如 /ws/)做出正确的代理

相关推荐
VidDown3 分钟前
热门短视频平台的视频编码技术解(VidDown)
网络协议·编辑器·音视频·视频编解码·视频
遇事不決洛必達6 分钟前
【爬虫随笔】深入理解 HTTP/HTTPS 协议、接口交互与会话机制
爬虫·网络协议·http·https·session
ttwuai23 分钟前
XYGo Admin 扩展开发:WebSocket 事件注册与实时推送实战
python·websocket·网络协议·golang·后台框架
喵了几个咪37 分钟前
实时游戏网络协议深度对比:KCP vs WebRTC vs WebSocket
网络协议·游戏·webrtc
万能的知了1 小时前
WAF、高防IP、CC防护:安全产品到底怎么选
服务器·网络协议·安全
81250353312 小时前
第13篇:TCP vs UDP——可靠与速度的博弈
网络协议·tcp/ip·udp
喵个咪15 小时前
实时游戏网络协议深度对比:KCP vs WebRTC vs WebSocket
后端·websocket·webrtc
代码中介商15 小时前
HTTP 完全指南(最终篇):CORS 跨域资源共享深度详解
网络·网络协议·http
user732639210047816 小时前
借助AI再次理解三次握手和四次挥手
网络协议·面试
abcefg_h16 小时前
HTTP 协议版本演进:从 TCP 连接到 QUIC
网络·网络协议·http