如何Redis解决WebSocket分布式场景下的Session共享问题

在显示项目中遇到了一个问题,需要使用到websocket与小程序建立长链接。由于项目是负载均衡的,存在项目部署在多台机器上。这样就会存在一个问题,当一次请求负载到第一台服务器时,socketsession在第一台服务器线程上,第二次请求,负载到第二台服务器上,需要通过id查找当前用户的session时,是查找不到的。

可以看到,由于websocket的session并没有实现序列化接口。所以无法将session序列化到redis中。 web的中的httpsession 主要是通过下面的两个管理器实现序列化的。
org.apache.catalina.session.StandardManager
org.apache.catalina.session.PersistentManager
StandardManager是Tomcat默认使用的,在web应用程序关闭时,对内存中的所有HttpSession对象进行持久化,把他们保存到文件系统中。
默认的存储文件为:/work/Catalina/<主机名

如何Redis解决WebSocket分布式场景下的Session共享问题最先出现在Python成神之路

版权声明:
作者:主机优惠
链接:https://www.techfm.club/p/24201.html
来源:TechFM
文章版权归作者所有,未经允许请勿转载。

THE END
分享
二维码
< <上一篇
下一篇>>