MQTT---HiveMQ源码详解(十六)TopicTree
来源:互联网 发布:新东方网络视频哪里买 编辑:程序博客网 时间:2024/04/26 17:23
源博客地址:http://blog.csdn.net/pipinet123
MQTT交流群:221405150
功能
启动时,读取持久化的信息,构建出订阅树
根据可订阅/取消订阅/读取订阅(包括计算出QoS)
类图
既然是一棵树,那么肯定是由一堆Node组成的,TopicTreeNode持有当前的topic的segment,通配符订阅者信息(包含订阅者、订阅的QoS、是否共享订阅、以及共享订阅组信息)。
每个节点都可以提供订阅、取消订阅、获得订阅者信息、以及一些订阅树节点的数据的增删改查操作。
TopicTree实现类持有了node的根结点,与每个节点一致提供对应订阅树的操作。
Persistence相关的处理与支持的业务基本上与上节讲解一致,此处就不多作赘述了。
TopicTreeBootstrap在broker启动时根据cluster中client session、client session subscriptions、shared subscription来在内存中构建出这一棵树,以便在后续使用时,能够在内存中实时获得到同步的内存订阅树。
订阅树是在每种类型的mqtt broker中几乎都会存在的,订阅树的问题属于优化问题,只有针对符合的场景才能发挥其结构、存储、设计的巧妙。
0 0
- MQTT---HiveMQ源码详解(十六)TopicTree
- MQTT---HiveMQ源码详解(一)概览
- MQTT---HiveMQ源码详解(三)配置加载
- MQTT---HiveMQ源码详解(四)插件加载
- MQTT---HiveMQ源码详解(八)Netty-WebSocket
- MQTT---HiveMQ源码详解(九)Netty-Codec
- MQTT---HiveMQ源码详解(十)Netty-Statistics
- MQTT---HiveMQ源码详解(十一)Netty-Throttling
- MQTT---HiveMQ源码详解(十四)Persistence-LocalPersistence
- MQTT---HiveMQ源码详解(二)结构与启动
- MQTT---HiveMQ源码详解(五)Netty-启动与Listeners加载
- MQTT---HiveMQ源码详解(外传)为什么使用Xodus
- MQTT---HiveMQ源码详解(六)Netty-Handlers总览
- MQTT---HiveMQ源码详解(七)Netty-SSL/NoSSL
- MQTT---HiveMQ源码详解(十五)Persistence-Cluster/Single
- MQTT---HiveMQ源码详解(十八)Cluster-kryo与Serializer
- MQTT---HiveMQ源码详解(十九)Cluster-Request/Response
- MQTT---HiveMQ源码详解(二十)Cluster-Replicate/VectorClock
- LeetCode : Power of Three
- 推荐系统概述
- 用辗转相除法求最大公约数
- 秒杀系统架构
- AVR单片机笔记 mega16 PC口2345管脚
- MQTT---HiveMQ源码详解(十六)TopicTree
- CPU简史
- 记面试中知识疑惑点
- c语言进程池的简单实现
- Android组件----Activity
- 数据库跨越访问
- k-邻近算法学习
- tensorflow function笔记: dropout
- NYOJ-71 独木舟上的旅行(贪心)