博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MQTT---HiveMQ源码详解(十六)TopicTree
阅读量:3610 次
发布时间:2019-05-21

本文共 519 字,大约阅读时间需要 1 分钟。

源博客地址:


MQTT交流群:221405150


功能

  • 启动时,读取持久化的信息,构建出订阅树

  • 根据可订阅/取消订阅/读取订阅(包括计算出QoS)

类图

这里写图片描述

  • 既然是一棵树,那么肯定是由一堆Node组成的,TopicTreeNode持有当前的topic的segment,通配符订阅者信息(包含订阅者、订阅的QoS、是否共享订阅、以及共享订阅组信息)。

  • 每个节点都可以提供订阅、取消订阅、获得订阅者信息、以及一些订阅树节点的数据的增删改查操作。

  • TopicTree实现类持有了node的根结点,与每个节点一致提供对应订阅树的操作。

  • Persistence相关的处理与支持的业务基本上与上节讲解一致,此处就不多作赘述了。

  • TopicTreeBootstrap在broker启动时根据cluster中client session、client session subscriptions、shared subscription来在内存中构建出这一棵树,以便在后续使用时,能够在内存中实时获得到同步的内存订阅树。

订阅树是在每种类型的mqtt broker中几乎都会存在的,订阅树的问题属于优化问题,只有针对符合的场景才能发挥其结构、存储、设计的巧妙。

你可能感兴趣的文章
spriingboot -- spring-security 对页面资源的认证与授权
查看>>
类比较器Comparator
查看>>
Vue.js简单模板
查看>>
Vue.js基本操作语法
查看>>
pom.xml内容没错, 但第一行有红叉
查看>>
@Qualifier注解
查看>>
Shiro框架初步认识
查看>>
Shiro密码加密加盐
查看>>
reidis设置key org.springframework.expression.spel.SpelEvaluationException: EL1008E
查看>>
Elasticsearch搜索引擎与Kibana搜索引擎数据查看工具的简单运用
查看>>
org.springframework.data.redis.RedisConnectionFailureException: Cannot get Jedis connection异常
查看>>
springboot thymeleaf 引用静态资源时要注意的事项
查看>>
分页代码
查看>>
Vue三元动态设置class
查看>>
springboot前端上传图片, 后端需要刷新项目本地文件夹才能访问
查看>>
window. location. search的用法
查看>>
关于ajax、axios的请求格式后端接收的注意点
查看>>
关于axios
查看>>
org.hibernate.LazyInitializationException: could not initialize proxy - no Session
查看>>
SpringBoot-JPA自定义SQL(分页)语句
查看>>