Redis的Pub/Sub客户端实现
前言
在学习T-io框架,从写一个Redis客户端开始一文中,已经简单介绍了Redis
客户端的实现思路,并且基础架构已经搭建完成,只不过支持的命令不全,不过后期在加命令就会很简单了。本篇就要实现Publish/Subscribe
功能。
Pub/Sub
发布订阅模式在很多场景中用的都很频繁,这里不再赘述。下面看一下Redis
中的命令。参考资料:https://redis.io/topics/pubsub
//发布
PUBLISH
//订阅
SUBSCRIBE
//模式匹配订阅
PSUBSCRIBE
//取消订阅
UNSUBSCRIBE
//取消订阅(模式匹配)
PUNSUBSCRIBE
//其他
PUBLISH/SUBSCRIBE
命令使用方式很简单:
PUBLISH CHANNEL MESSAGE
例如:publish user helloworld
Client
类中增加代码:
@Override
public void publish(final String channel, final String message) {
sendCommand(Command.PUBLISH, channel, message);
}
@Override
public void subscribe(final String... channels) {
sendCommand(SUBSCRIBE, channels);
}
调试代码如下:
//发布
Tedis tedisPublish = new Tedis("192.168.1.225", 6379);
tedisPublish.publish("channel1","hello world");
//订阅
Tedis tedis = new Tedis("192.168.1.225", 6379);
tedis.subscribe(new MyPubSub(),"channel1");
先订阅,后发布,订阅响应结果:
*3
$9
subscribe
$8
channel1
:1
通过响应结果可以看出,我们当前的命令是 subscribe
,然后订阅的是channel1
,当前共订阅了:1
个。
发布响应结果:
:1
总共发给了:1
个订阅客户端。这个结果就是订阅客户端的个数。
PSUBSCRIBE
命令格式如下:
PSUBSCIRBE news.*
修改一下调试代码:
订阅
tedis.pSubscribe(new MyPubSub(),"news.*");
响应结果:
*3
$10
psubscribe
$6
news.*
:1
发布
tedisPublish.publish("news.sports","welcome to NBA");
tedisPublish.publish("news.country","this is china news");
订阅客户端收到消息:
*4
$8
pmessage
$6
news.*
$11
news.sports
$14
welcome to NBA
*4
$8
pmessage
$6
news.*
$12
news.country
$18
this is china news
从响应结果可以看出,客户端订阅了 news.*
,然后收到了news.sports,news.country
的消息。
响应消息解析
上述代码中有一个MyPubSub
对象,它继承自抽象类TedisPubSub
.这个类做了发布订阅核心的业务处理。通过对服务端返回的消息格式,我们可以发现,它的消息格式是统一的。
EVENT_NAME --事件
CHANNEL_NAME --频道
OTHER --其他信息,根据每个事件可能不同
所以我们在做发布订阅的响应消息解析时,可以返回 List
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?