内容简介:博主使用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分钟了解负载均衡,分清二层负载均衡和三层负载均衡
- 负载均衡策略之有限负载一致性哈希
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Web协议与实践
克里希纳穆尔蒂 (KrishnamurthyBalachander) / 范群波 / 科学出版社 / 2003-7 / 46.0
本书全面论述了传输Web内容的系统和协议,重点讲述了Web中业已成熟和稳定的技术,如TCP/IP协议及DNS技术、HITP/1.0的设计及其与TCP之间的交互;深入阐述了Web高速缓存技术和多媒体流播技术的最新技术动态;分析了Apache Web服务器和Squid代理;还探讨了通信量的分析和测量技术。书中使用了大量示例、技术发展水平报告以及案例分析来阐述Web的工作原理和各个组件之间的交互。本书是......一起来看看 《Web协议与实践》 这本书的介绍吧!