内容简介:博主使用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分钟了解负载均衡,分清二层负载均衡和三层负载均衡
- 负载均衡策略之有限负载一致性哈希
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
人人时代(经典版)
[美] 克莱•舍基(Clay Shirky) / 胡泳、沈满琳 / 浙江人民出版社 / 2015-6 / 54.90元
[内容简介] 一而再,再而三出现的公众事件,绝不仅是来自草根的随兴狂欢,而是在昭示着一种变革未来的力量之崛起!基于爱、正义、共同的喜好和经历,人和人可以超越传统社会的种种限制,灵活而有效地采用即时通信、移动电话、网络日志和维基百科等新的社会性工具联结起来,一起分享、合作乃至展开集体行动。人人时代已经到来。 微软、诺基亚、宝洁、BBC、乐高、美国海军最推崇的咨询顾问,“互联网革命最伟大的......一起来看看 《人人时代(经典版)》 这本书的介绍吧!