Nginx反向代理WebSocket服务连接报错:WebSocket connection to “wss://xxx/xxx“ failed

最近使用 node.js 搭建 WebSocket 服务,在本地测试 connection 都是正常,于是部署到 Linux 服务上,需要用 Nginx 来反向代理 WebSocket 服务。浏览器控制台报错:WebSocket connection to 'wss://tiven.cn/ws/xxx' failed:,经过一番折腾,终于解决了这个报错。

Nginx WebSocket

介绍

WebSocket 协议与 HTTP 协议不同,但 WebSocket 握手与 HTTP 兼容,使用 HTTP 升级工具将连接从 HTTP 升级到 WebSocket。这允许 WebSocket 应用程序更容易地适应现有的基础架构。例如,WebSocket 应用程序可以使用标准 HTTP 端口80和443,从而允许使用现有的防火墙规则。

WebSocket 应用程序可以在客户端和服务器之间保持长时间运行的连接,从而有助于开发实时应用程序。 Nginx 反向代理用于将连接从 HTTP 升级到 WebSocket 的 HTTP 升级机制使用 UpgradeConnection 。反向代理服务器在支持 WebSocket 时面临一些挑战。一个是 WebSocket 是一个逐跳协议,因此当代理服务器拦截客户端的升级请求时,需要向后端服务器发送自己的升级请求,包括相应的头文件。此外,由于 WebSocket 连接长期存在,与 HTTP 使用的典型短期连接相反,反向代理需要允许这些连接保持打开状态,而不是关闭它们,因为它们似乎处于空闲状态。

允许在客户机和后端服务器之间建立隧道,Nginx 支持 WebSocket。对于 Nginx 将升级请求从客户端发送到后台服务器,必须明确设置 UpgradeConnection 标题。

总的来说,就是使用 Nginx 反向代理 WebSocket 服务时需要设置 UpgradeConnectionheader

nginx 配置

  1. 出现报错时的配置
location /ws {
    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;
    proxy_pass        http://127.0.0.1:9000/ws;
}            
  1. 反向代理成功的配置
location /ws {
    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;
    proxy_pass        http://127.0.0.1:9000/ws;
    
    # 关键配置 start
    proxy_http_version 1.1;
    proxy_set_header Upgrade $http_upgrade;
    proxy_set_header Connection "upgrade";
    # 关键配置 end
}            

完美解决报错问题(WebSocket connection to "xxx/xxx" failed)。


Nginx 相关推荐


欢迎访问:天问博客

  • 28
    点赞
  • 68
    收藏
    觉得还不错? 一键收藏
  • 14
    评论
这个错误通常表示WebSocket连接失败,原因是无效的帧头。根据引用和引用,该错误可能由几个原因引起。一种可能性是WebSocket服务端无法连接到指定的URL。这可能是由于网络问题、服务器故障或URL设置错误引起的。另一种可能性是代理服务器配置不正确,导致反向代理WebSocket连接失败。根据引用,使用Nginx反向代理WebSocket服务时,需要正确配置Nginx以支持WebSocket连接。 要解决这个问题,你可以尝试以下几个步骤: 1. 确保WebSocket服务端的URL地址是正确的。检查URL是否包含正确的主机名、端口号和路径。确保WebSocket服务正在运行,并且可以通过指定的URL进行访问。 2. 检查网络连接是否正常。确保你的客户端能够与WebSocket服务端建立网络连接。你可以尝试使用其他网络设备或连接尝试重新连接。 3. 检查代理服务器配置是否正确。如果你正在使用代理服务器来反向代理WebSocket连接,确保你已正确配置Nginx或其他代理服务器以支持WebSocket连接。根据引用,你可能需要使用特定的配置选项来启用WebSocket支持,并确保代理服务器能够正确转发WebSocket请求。 4. 检查浏览器是否支持WebSocket。确保你正在使用支持WebSocket的浏览器版本。可以尝试在其他支持WebSocket的浏览器上测试连接,以确定是否是浏览器兼容性问题。 总结来说,当出现"WebSocket connection to 'ws://localhost:8080/ws' failed: Invalid frame header"错误时,可能是由于无法连接到指定的URL、代理服务器配置问题、网络问题或浏览器不支持WebSocket等原因导致的。你可以尝试根据上述步骤进行排查和解决。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [控制台反复输出WebSocket connection to ‘ws://10.133.212.203:8080/ws‘ failed:](https://blog.csdn.net/weixin_46466212/article/details/126762870)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Nginx反向代理WebSocket服务连接报错WebSocket connection to “wss://xxx/xxxfailed](https://blog.csdn.net/tiven_/article/details/126126442)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 14
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值