免费预览已结束,剩余1页可下载查看
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
Consumer端:RocketMQ提供了两种消费模式:PUSH(pull进行监听)和PULL(长轮训)1. Push 方式:rocketmq 已经提供了很全面的实现, consumer 通过长轮询拉取消息后回调MessageListener 接口实现完成消费, 应用系统只要 MessageListener 完成业务逻辑即可2. Pull 方式:完全由业务系统去控制,定时拉取消息,指定队列消费等等, 当然这里需要业务系统根据自己的业务需求去实现。这两种模式分别对应的是DefaultMQPushConsumer类和DefaultMQPullConsumer类设计:简化程序员使用rocketmq消息中间件,pull调用brokerorg.apache.rocketmq.client.impl.consumer.PullMessageService#run消费模型:tocol.heartbeat.MessageModel#BROADCASTINGtocol.heartbeat.MessageModel#CLUSTERING消费选择:mon.consumer.ConsumeFromWhere#CONSUME_FROM_LAST_OFFSET第一次启动从队列最后位置消费,后续再启动接着上次消费的进度开始消费mon.consumer.ConsumeFromWhere#CONSUME_FROM_FIRST_OFFSET第一次启动从队列初始位置消费,后续再启动接着上次消费的进度开始消费mon.consumer.ConsumeFromWhere#CONSUME_FROM_TIMESTAMP第一次启动从指定时间点位置消费,后续再启动接着上次消费的进度开始消费以上所说的第一次启动是指从来没有消费过的消费者,如果该消费者消费过,那么会在broker端记录该消费者的消费位置,如果该消费者挂了再启动,那么自动从上次消费的进度开始消息重复幂等:RocketMQ无法避免消息重复,所以如果业务对消费重复非常敏感,务必要在业务层面去重Ps:见开发文档 接口幂等性处理 redis incr 消息过滤:enablePropertyFilter=trueStatus=1 消费 status=2不需要为什么要有组group:?sh mqshutdown brokersh mqshutdown namesrvNamesrv端:Namesrv入口:srv.NamesrvStartupNamesrv 名称服务,是没有状态可集群横向扩展。可以理解为一个注册中心, 整个Namesrv的代码非常简单,主要包含两块功能:1、管理一些 KV 的配置2、管理一些 Topic、Broker的注册信息大致提供服务为:1. 每个 broker 启动的时候会向 namesrv 注册2. Producer 发送消息的时候根据 topic 获取路由到 broker 的信息3. Consumer 根据 topic 到 namesrv 获取 topic 的路由到 broker 的信息Broker端:程序入口:org.apache.rocketmq.broker.BrokerStartup存储&索引:存储文件结构:org.apache.rocketmq.store.index.IndexFile索引文件由索引文件头(IndexHeader)+( 槽位 Slot )+(消息的索引内容)三部分构成。beginTimestamp8 位 long 类型,索引文件构建第一个索引的消息落在 broker 的时间endTimestamp8 位 long 类型,索引文件构建最后一个索引消息落 broker 时间beginPhyOffset8 位 long 类型,索引文件构建第一个索引的消息 commitLog 偏移量endPhyOffset8 位 long 类型,索引文件构建最后一个索引消息 commitLog 偏移量hashSlotCount4 位 int 类型,构建索引占用的槽位数(这个值貌似没有具体作用) indexCount4 位 int 类型,索引文件中构建的索引个数槽位 slot默认每个文件配置的 slot 个数为 500 万个, 每个 slot 是 4 位的 int 类型数据计算消息的对应的 slotPos=Math.abs(keyHash)%hashSlotNum消息在 IndexFile 中的偏移量,Slot 存储的值为消息个数索引消息的索引内容是 20 位定长内容的数据4 位 int 值, 存储的是 key 的 hash 值8 位 long 值存储的是消息在 commitlog 的物理偏移量 phyOffset4 位 int 值存储了当前消息跟索引文件中第一个消息在 broker 落地的时间差4 位 int 值如果存在 hash 冲突,存储的是上一个消息的索引地址序列化在RocketMQ中,RemotingCommand这个类在消息传输过程中对所有数据内容的
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024年郑州幼儿师范高等专科学校马克思主义基本原理概论期末考试真题汇编
- 2025年重庆建筑科技职业学院马克思主义基本原理概论期末考试笔试题库
- 2024年重庆师范大学马克思主义基本原理概论期末考试笔试真题汇编
- 2024年南开大学马克思主义基本原理概论期末考试真题汇编
- 2025年北京第二外国语学院中瑞酒店管理学院马克思主义基本原理概论期末考试参考题库
- 2025年武汉电力职业技术学院马克思主义基本原理概论期末考试笔试真题汇编
- 2025年信息系统项目管理师考试云计算冲刺测试
- 四川省成都市郫都区2024-2025学年高一上学期期中考试政治试卷
- 游戏资料:海贼王无双2 影像开放条件
- 冷链物流冷库建设合同
- 无锡公建工程质量检测有限公司2025年下半年公开招聘专业技术人员备考题库及答案详解一套
- 部编版(2024)小学语文三年级上册期末综合质量调研卷(含答案)
- 2026年高级会计师面试题及答案解析
- 湖南省邵阳市2025-2026学年高二历史上学期期末模拟卷(试卷及全解全析)
- 2026年青海省海东地区单招职业倾向性测试模拟测试卷附答案
- 八年级数学 期末总结
- (2025版)腹膜后肿瘤诊治专家共识课件
- 2025年中国农业大学 高级生物化学 知到智慧树期末考试题库及答案
- 房地产公司各岗位绩效考核指标表4资料
- 基因编辑真菌鉴定
- 温泉洗浴行业分析报告
评论
0/150
提交评论