内容简介:博主使用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分钟了解负载均衡,分清二层负载均衡和三层负载均衡
- 负载均衡策略之有限负载一致性哈希
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
The Web Designer's Idea Book
Patrick Mcneil / How / 2008-10-6 / USD 25.00
The Web Designer's Idea Book includes more than 700 websites arranged thematically, so you can find inspiration for layout, color, style and more. Author Patrick McNeil has cataloged more than 5,000 s......一起来看看 《The Web Designer's Idea Book》 这本书的介绍吧!