首页 > 编程语言 > 详细

springcloud下实现websocket session共享

时间:2019-11-08 13:54:05      阅读:1459      评论:0      收藏:0      [点我收藏+]

  我们知道在单节点应用中我们只需要将websocketsession存储在ConcurrentHashMap中就OK,每次发送通知都从map中根据用户ID获取对应的websocket的session进行消息通知。

针对分布式系统,很多人第一时间想到的是websocket的session共享,这是大多数的第一反应。很遗憾的是,websocketsession不支持序列化操作,所以也就不能够存在redis等缓存中。

  那么我们还有什么其他的解决方案呢?

  我先大致说一下我的项目架构,springcloud项目,没有做前后端分离,所有请求都是经过web服务进行转发。

  好了,下面就来说说我是怎么解决的吧。

  技术分享图片

 

 

 

   如图,我是利用了redis的订阅发布机制实现信息共享的,web负责维护websocketsession,并监听redis

通道中的消息,将消息发送给对应的在线用户。业务服务都统一通过接口服务将消息发布到redis,这样子就不

需要每个服务都去做配置了。做到服务间职能清晰。

  redis配置如下:

技术分享图片

  websocket相关配置请参考:

  https://mp.weixin.qq.com/s?__biz=MzIwMDY0Nzk2Mw==&mid=2650320716&idx=1&sn=16b403171f157242a8efc5523b20a41b&chksm=8ef5fb38b982722eddc8290969d58a3d11d9f615fc6041b970195aa81481b51a09fd87a7ab72&mpshare=1&scene=1&srcid=&sharer_sharetime=1572350750203&sharer_shareid=3f213a187195d4a3135c81d985c37ffb&key=5929baa0c2a9114046a60a85204558476947ed05cbcfc087bc6117697b49ff966fbc98a3ec5a4fb81874433e158c28bc0f198302a88104658185548fdbe8ee4ddcacd532e655a896365ab9d182042344&ascene=1&uin=MTMwMTY1ODQ0NA%3D%3D&devicetype=Windows+10&version=62060834&lang=zh_CN&pass_ticket=5INtnmN0Q42zEHuxfVo8TJvzTUjl3CCaMa%2BAzOtmjpuD2jVu%2FGi22FPlYaMMN6iS

  本人采用的是jdk自带的,在javax.websocket包下。

  当然针对各个项目情况还有多种解决办法,这里就不在一一赘述,具体情况具体分析。

springcloud下实现websocket session共享

原文:https://www.cnblogs.com/sly1994/p/11815705.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!