• RocketMQ源码解析-topic创建机制


    1. RocketMQ Topic创建机制

    RocketMQ Topic创建机制分为两种:一种自动创建,一种手动创建。可以通过设置broker的配置文件来禁用或者允许自动创建。默认是开启的允许自动创建

    autoCreateTopicEnable=true/false

    下面会结合源码来深度分析一下自动创建和手动创建的过程。

    2. 自动Topic

    默认情况下,topic不用手动创建,当producer进行消息发送时,会从nameserver拉取topic的路由信息,如果topic的路由信息不存在,那么会默认拉取broker启动时默认创建好名为“TBW102”的Topic,这定义在org.apache.rocketmq.common.MixAll类中

    1. // Will be created at broker when isAutoCreateTopicEnable
    2. public static final String AUTO_CREATE_TOPIC_KEY_TOPIC = "TBW102";
    3. 复制代码

    自动创建开关是下BrokerConfig类中有一个私有变量:

    1. @ImportantField
    2. private boolean autoCreateTopicEnable = true;
    3. 复制代码

    这变量可以通过配置文件配置来进行修改,代码中的默认值为true,所以在默认的情况下Rocket MQ是会自动创建Topic的。
    在Broker启动,会调用TopicConfigManager的构造方法,在构造方法中定义了一系列RocketMQ系统内置的一些系统Topic(这里只关注一下TBW102):

    1. {
    2. // MixAll.AUTO_CREATE_TOPIC_KEY_TOPIC
    3. if (this.brokerController.getBrokerConfig().isAutoCreateTopicEnable()) {
    4. String topic = MixAll.AUTO_CREATE_TOPIC_KEY_TOPIC;
    5. TopicConfig topicConfig = new TopicConfig(topic);
    6. this.systemTopicList.add(topic);
    7. topicConfig.setReadQueueNums(this.brokerController.getBrokerConfig()
    8. .getDefaultTopicQueueNums()); //8
    9. topicConfig.setWriteQueueNums(this.brokerController.getBrokerConfig()
    10. .getDefaultTopicQueueNums()); //8
    11. int perm = PermName.PERM_INHERIT | PermName.PERM_READ | PermName.PERM_WRITE;
    12. topicConfig.setPerm(perm);
    13. this.topicConfigTable.put(topicConfig.getTopicName(), topicConfig);
    14. }
    15. }
    16. 复制代码

    这里有 this.brokerController.getBrokerConfig().isAutoCreateTopicEnable() 这样一段代码,在开启允许自动创建的时候,会把当前Topic的信息存入topicConfigTable变量中。然后通过发送定期发送心跳包把Topic和Broker的信息发送到NameServer的RouteInfoManager中进行保存。在BrokerController中定义了这样的一个定时任务来执行这个心跳包的发送:

    1. this.scheduledExecutorService.scheduleAtFixedRate(new Runnable() {
    2. @Override
    3. public void run() {
    4. try {
    5. BrokerController.this.registerBrokerAll(true, false, brokerCon
  • 相关阅读:
    Python学习第10天:类与对象
    设计模式学习笔记(二十)状态模式及其实现
    【ECS游戏架构】逻辑帧驱动带来的性能和即时性问题分析
    五、yolov8 tensorRT c++部署及接口封装(保姆级教程&附源码)
    YOLOv7模型训练
    亚马逊、速卖通自养号测评技术:快速提升店铺产品转化率的权重和销量
    深度学习的进展,产业化,规模化、数据化
    七大排序之希尔排序
    企业如何反爬虫?
    【神经网络】梯度消失与梯度爆炸问题
  • 原文地址:https://blog.csdn.net/Trouvailless/article/details/126425977