内容简介:博主使用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分钟了解负载均衡,分清二层负载均衡和三层负载均衡
- 负载均衡策略之有限负载一致性哈希
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
深入理解计算机系统(原书第3版)
Randal E.Bryant、David O'Hallaron / 龚奕利、贺莲 / 机械工业出版社 / 2016-11 / 139.00元
和第2版相比,本版内容上*大的变化是,从以IA32和x86-64为基础转变为完全以x86-64为基础。主要更新如下: 基于x86-64,大量地重写代码,首次介绍对处理浮点数据的程序的机器级支持。 处理器体系结构修改为支持64位字和操作的设计。 引入更多的功能单元和更复杂的控制逻辑,使基于程序数据流表示的程序性能模型预测更加可靠。 扩充关于用GOT和PLT创建与位置无关代码的......一起来看看 《深入理解计算机系统(原书第3版)》 这本书的介绍吧!