聊聊claudb的pubsub command
时间:2022-07-24
本文章向大家介绍聊聊claudb的pubsub command,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
序
本文主要研究一下claudb的pubsub command
PublishCommand
claudb-1.7.1/src/main/java/com/github/tonivade/claudb/command/pubsub/PublishCommand.java
@Command("publish")
@ParamLength(2)
public class PublishCommand implements DBCommand, SubscriptionSupport, PatternSubscriptionSupport {
@Override
public RedisToken execute(Database db, Request request) {
String channel = request.getParam(0).toString();
SafeString message = request.getParam(1);
return integer(publishAll(getClauDB(request.getServerContext()), channel, message));
}
private int publishAll(DBServerContext server, String channel, SafeString message) {
int count = publish(server, channel, message);
int pcount = patternPublish(server, channel, message);
return count + pcount;
}
}
- PublishCommand实现了DBCommand, SubscriptionSupport, PatternSubscriptionSupport接口,其execute方法执行publishAll(getClauDB(request.getServerContext()), channel, message)
SubscribeCommand
claudb-1.7.1/src/main/java/com/github/tonivade/claudb/command/pubsub/SubscribeCommand.java
@ReadOnly
@Command("subscribe")
@ParamLength(1)
@PubSubAllowed
public class SubscribeCommand implements DBCommand, SubscriptionSupport {
private static final String SUBSCRIBE = "subscribe";
@Override
public RedisToken execute(Database db, Request request) {
Database admin = getAdminDatabase(request.getServerContext());
String sessionId = getSessionId(request);
Sequence<SafeString> channels = getChannels(request);
int i = channels.size();
List<Object> result = new LinkedList<>();
for (SafeString channel : request.getParams()) {
addSubscription(admin, sessionId, channel);
getSessionState(request.getSession()).addSubscription(channel);
result.addAll(asList(SUBSCRIBE, channel, ++i));
}
return convert(result);
}
private String getSessionId(Request request) {
return request.getSession().getId();
}
private Sequence<SafeString> getChannels(Request request) {
return getSessionState(request.getSession()).getSubscriptions();
}
}
- SubscribeCommand实现了DBCommand, SubscriptionSupport接口,其execute方法遍历channel挨个执行addSubscription及getSessionState(request.getSession()).addSubscription(channel)
UnsubscribeCommand
claudb-1.7.1/src/main/java/com/github/tonivade/claudb/command/pubsub/UnsubscribeCommand.java
@ReadOnly
@Command("unsubscribe")
@ParamLength(1)
@PubSubAllowed
public class UnsubscribeCommand implements DBCommand, SubscriptionSupport {
private static final String UNSUBSCRIBE = "unsubscribe";
@Override
public RedisToken execute(Database db, Request request) {
Database admin = getAdminDatabase(request.getServerContext());
String sessionId = getSessionId(request);
Sequence<SafeString> channels = getChannels(request);
int i = channels.size();
List<Object> result = new LinkedList<>();
for (SafeString channel : request.getParams()) {
removeSubscription(admin, sessionId, channel);
getSessionState(request.getSession()).removeSubscription(channel);
result.addAll(asList(UNSUBSCRIBE, channel, --i));
}
return convert(result);
}
private String getSessionId(Request request) {
return request.getSession().getId();
}
private Sequence<SafeString> getChannels(Request request) {
return getSessionState(request.getSession()).getSubscriptions();
}
}
- UnsubscribeCommand实现了DBCommand, SubscriptionSupport接口,其execute方法遍历channel挨个执行removeSubscription(admin, sessionId, channel)及getSessionState(request.getSession()).removeSubscription(channel)
PatternSubscribeCommand
claudb-1.7.1/src/main/java/com/github/tonivade/claudb/command/pubsub/PatternSubscribeCommand.java
@ReadOnly
@Command("psubscribe")
@ParamLength(1)
@PubSubAllowed
public class PatternSubscribeCommand implements DBCommand, PatternSubscriptionSupport {
private static final String PSUBSCRIBE = "psubscribe";
@Override
public RedisToken execute(Database db, Request request) {
Database admin = getAdminDatabase(request.getServerContext());
String sessionId = getSessionId(request);
Sequence<SafeString> channels = getChannels(request);
int i = channels.size();
List<Object> result = new LinkedList<>();
for (SafeString pattern : request.getParams()) {
addPatternSubscription(admin, sessionId, pattern);
getSessionState(request.getSession()).addSubscription(pattern);
result.addAll(asList(PSUBSCRIBE, pattern, ++i));
}
return convert(result);
}
private String getSessionId(Request request) {
return request.getSession().getId();
}
private Sequence<SafeString> getChannels(Request request) {
return getSessionState(request.getSession()).getSubscriptions();
}
}
- PatternSubscribeCommand实现了DBCommand, PatternSubscriptionSupport接口,其execute方法遍历pattern挨个执行addPatternSubscription(admin, sessionId, pattern)及getSessionState(request.getSession()).addSubscription(pattern)
PatternUnsubscribeCommand
claudb-1.7.1/src/main/java/com/github/tonivade/claudb/command/pubsub/PatternUnsubscribeCommand.java
@ReadOnly
@Command("punsubscribe")
@ParamLength(1)
@PubSubAllowed
public class PatternUnsubscribeCommand implements DBCommand, PatternSubscriptionSupport {
private static final String PUNSUBSCRIBE = "punsubscribe";
@Override
public RedisToken execute(Database db, Request request) {
Database admin = getAdminDatabase(request.getServerContext());
String sessionId = getSessionId(request);
Sequence<SafeString> channels = getChannels(request);
int i = channels.size();
List<Object> result = new LinkedList<>();
for (SafeString channel : request.getParams()) {
removePatternSubscription(admin, sessionId, channel);
getSessionState(request.getSession()).removeSubscription(channel);
result.addAll(asList(PUNSUBSCRIBE, channel, --i));
}
return convert(result);
}
private String getSessionId(Request request) {
return request.getSession().getId();
}
private Sequence<SafeString> getChannels(Request request) {
return getSessionState(request.getSession()).getSubscriptions();
}
}
- PatternUnsubscribeCommand实现了DBCommand, PatternSubscriptionSupport接口,其execute遍历channel挨个执行removePatternSubscription(admin, sessionId, channel)及getSessionState(request.getSession()).removeSubscription(channel)
小结
claudb pubsub相关的command有PublishCommand、SubscribeCommand、UnsubscribeCommand、PatternSubscribeCommand、PatternUnsubscribeCommand
doc
- Python-Socket
- 用Sysctl 调整Linux操作系统的性能
- python-基础案例
- css3 3d变换和动画——回顾
- eclipse中关联文件设置方法
- Kubernetes服务网格(第8部分):Linkerd作为入口控制器
- 使用RestSharp 库消费Restful Service
- Python-面向对像及其他
- 基于MongoDB GridFS的图片存储
- css3 过渡和2d变换——回顾
- Microsoft 防跨站点脚本库AntiXSS Library v4.2.1
- Compilify——让你在浏览器中编译.NET代码
- Python进阶-面向对象
- WCF RESTful服务的Google Protocol Buffers超媒体类型
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- SpringMVC配置字符过滤器的两种方式
- SpringMvc使用Json(Java配置方式)
- 使用IDEA创建SpringMvc并整合Thymeleaf(Java配置版)
- Junit报错:Argument(s) are different! Wanted:
- RocketMQ使用过滤器filterServer(4.3版本后)
- Python+Appium运行简单的demo,你需要理解Appium运行原理!
- 网站日志分析完整实践【技术创造101训练营】
- HTML前端知识
- 掌握 AST,轻松落地关键业务「技术创作101训练营」
- 一文轻松学会linux字符设备驱动
- leetcode树之N叉树的前序遍历
- 2020-09-20:如何判断一个数是质数?
- 金九银十Android面试复习题集:关于四大组件中的Activity你了解多少?
- HaseMap的循环姿势你真的懂了吗?
- 历经14天自定义3个注解解决项目的3个Swagger难题