内容简介:博主使用nodejs后端koa2框架连接socket的代码(省略koa2的逻辑代码)
博主使用nodejs koa2 框架,在用 socket.io 做负载均衡后http请求socket抛出
HTTP Response {"code":1,"message":"Session ID unknown"}
错误
后端koa2框架连接socket的代码(省略koa2的逻辑代码)
// app.js
const Koa = require('koa')
const app = new Koa()
...
// 全局socket(设为全局为了方便事物处理)
global.io = require('socket.io-emitter')({
port: 6379, //端口
host: '127.0.0.1', //地址
password: '' //访问密码
});
// socket
var server = require('http').Server(app.callback()),
io = require('socket.io')(server)
// io adapter redis
io.adapter(redis({
port: 6379, //端口
host: '127.0.0.1', //地址
password: '' //访问密码
}));
// socket端口
server.listen(6003)
module.exports = app
前端socket连接
var socket = io(socketUri)
socket.on('connect', function(){
...
})
原本以为是因为多台socket服务器没有连接到同一个 io adapter
导致 session id
互相不认识,
但是明显代码中都是使用的同一个redis,于是排除了这个问题。
查阅多方issue发现了 需要修改socket的连接方式 ,于是修改前端socket连接配置如下
var socket = io(httpUrl, {
path: '/socket.io',
transports: ['websocket'],
secure: true,
});
重新启动,发现连接正常了,并且连接方式由 http
变成了 ws
连接
happy coding!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 负载均衡策略之最少连接
- imi v0.2 发布,性能提升 50%,支持连接池负载均衡
- imi v0.2 发布,性能提升 50%,支持连接池负载均衡
- MySQL-ProxySQL读写分离连接池负载均衡分库分表故障切换查询重写流量镜像SQL审计自动重连自动下线...
- 3分钟了解负载均衡,分清二层负载均衡和三层负载均衡
- 负载均衡策略之有限负载一致性哈希
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。