Socket.io 部署遇到的坑

本贴最后更新于 1630 天前,其中的信息可能已经物是人非

问题:

服务端使用了 namespace 来隔离作用域,也没增加其它配置

一开始使用 ip+ 端口的方式与服务端连接,一切正常,后来采用 nginx 部署的方式,就凉凉了。

错误信息

Socket.io connection error: Invalid namespace.

排查过程

首先检查 nginx 的配置文件,确保支持 socket 连接

详:https://www.nginx.com/blog/nginx-nodejs-websockets-socketio/

配置都没问题后,还是无法正常运转,无奈之下只能去查看 nignx 日志,然后就发现了这么一行

"GET /socket.io/?EIO=3&transport=polling&t=N9_C80w&b64=1 HTTP/1.1" 404 153 "-" "node-XMLHttpRequest"

然后我就懵了,下面是我的配置

        location /socket-bridge {
            proxy_pass             http://127.0.0.1:6017;
        }

我明明配置的是 /socket-bridge 并且客户端连接也没问题,那么问题来了,我明明连接的是 /socket-bridge 为什么到了 nginx 这边就成 /socket.io了 呢?

然后我试图将 nginx 中配置更改为

        location  /socket.io {
            proxy_pass             http://127.0.0.1:6017;
        }

结果!!!它就好了!!!

然后,我去仔细核对了一下正式环境中的网关配置(这里指生产环境的 nginx 配置),发现 /socket.io 已经被使用

        location /socket.io/ {
            proxy_pass             http://mercurius;
        }

然后我就明白为什么它会给我报上面那个错误了,原来连接都被代理到 mercurius 去了,但是 mercurius 又不存在我所连接的 namespace

然后,根据查文档,又有新的发现,发现连接的时候有一个 path 参数。

image.png

原来是因为我没有配置 path 参数导致 nginx 收到的连接都是以默认值 /socket.io 开头的。

socket 与 http 接口不同

如何解决

增加 path 参数

  • Node.js

    Node.js 是一个基于 Chrome JavaScript 运行时建立的平台, 用于方便地搭建响应速度快、易于扩展的网络应用。Node.js 使用事件驱动, 非阻塞 I/O 模型而得以轻量和高效。

    139 引用 • 269 回帖 • 43 关注
  • 一些有用的避坑指南。

    69 引用 • 93 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...