问题:
服务端使用了 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
参数。
原来是因为我没有配置 path 参数导致 nginx 收到的连接都是以默认值 /socket.io
开头的。
socket 与 http 接口不同
如何解决
增加 path 参数
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于