websocket与redis合用,保存用户状态并交互

在这里插入图片描述

websocket是双向通信的,client端可以向server端发送消息,server端也可以向client端发送消息。websocket有个session,叫WebSocketSession,它没有实现序列化接口Serializable,所以它无法保存到redis中,因为保存到redis中的对象必须是经过序列化的,即实现了Serializable接口。

那么,集群环境,websocket用户状态信息如何保存?server端如何将消息准确的发送到指定的client端?

我在项目中采用的方案是:每台机器都保存建立websocket连接的用户ID与WebSocketSession的关系,即Map<String, WebSocketSession>,同时将websocket的用户状态信息保存到redis中,比如用户ID等。当server端需要发送消息给client端时,利用redis的发布订阅功能,将消息发送到管道中,同时集群中的所有server端都订阅该管道,然后各server端从Map<String, WebSocketSession>中找到用户ID对应的WebSocketSession,找不到就略过,说明建立websocket连接的不是该server端,找到就利用WebSocketSession发送消息给client端。

设计思路如上图。聪明的你,明白了吗

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值