RocketMQ客户端源码分析-DefaultMQProducer

本文详细分析了RocketMQ客户端DefaultMQProducer的结构、启动过程和发送消息的逻辑。在start阶段,主要涉及MQClientInstance的初始化,包括APIImpl、定时任务、拉消息服务和再平衡服务的启动。在send过程中,首先匹配TopicPublishInfo,然后选择队列,最后通过APIImpl将消息发送给Broker。RocketMQ客户端缓存主题信息并实现消息队列的轮询发送。
摘要由CSDN通过智能技术生成
结构

DefaultMQProducer包含了DefaultMQProducerImpl,而DefaultMQProducerImpl又包含了MQClientInstance。
在这里插入图片描述

start

start的逻辑主要在MQClientInstance,做了这四个事情:

  • this.mQClientAPIImpl.start();
    APIImpl主要负责对外的API请求,比如在需要获取broker状态时就需要调用APIImpl的方法来获取,APIImpl里包含一个NettyRemoteClient,用于和nameServer通讯。
  • this.startScheduledTask();
    启动一些定时任务
  • this.pullMessageService.start();
    启动拉消息服务,无论是使用push还是pull来获取消息,实际都是在pull,只是自动pull还是手动pull的区别
  • this.rebalanceService.start();
    消费组里的消费者会分摊队列,就是通过rebalanceService来实现
send

send的逻辑主要在DefaultMQProducerImpl中,默认是以sync的方式发布,超时时间为3s,我们主要看sendDefaultImpl方法。


                
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值