RocketMQ5.x的pop模式如何解决消费堆积问题

RocketMQ4.X现存问题

在这里插入图片描述

  • 消费能力不能随POD增加而增加。
    理想情况下,POD数量小于QUEUE的数量,增加机器是能提高消能力的。
    现实情况下,如果POD数量大于QUEUE的数量,那么多的POD机器就不会处理消费,是一种资源的浪费。

  • 单节点HANG住影响整个TOPIC

  • 云原生支持较差。4.x的架构如下图所示,Producer和Broker都是有状态的,所以需要抽取一部分无状态的模块,所以5.x新增了Proxy。
    在这里插入图片描述

  • 富客户端需要优化,接入协议需要支持
    重平衡的业务逻辑是在客户端做的,当然还有其他的,轻量级的API客户端是5版本的发力点。要做大做强,还要支持更多的协议。

在这里插入图片描述

5.X的pop消费模式

结论先行

先插入一个结论,Cousumer请求broker消费消息的时候,带的queueId = -1,在源码中表示的就是全部QUEUE
!](https://img-blog.csdnimg.cn/direct/962335e937ad49f38b59332ba7cbe2ac.png)

所以逻辑上一个Conumser能拿到所有的队列消息。

场景分析

以场景为例,假设有2台POD,一个TOPIC只有一个队列,在设置了POP拉取模式下,批量拉取的上限为2,整个消费过程如下图所示。
在这里插入图片描述

【POD1】步骤1:请求broker获取消息,此时有4/5的流量会打到目标TOPIC上,先关注一下还有与目标TOPIC一一对应的RETRY_TOPIC
在这里插入图片描述

步骤2:【POD1】此时会把取到的两条消息,封装为一个PopCheckPoint (CK),叫到CK集合里。
步骤3:【POD1】broker把MSG12给pod1。
步骤4:【POD2】此时也请求Broker获取两条消息,此时获取的是MSG3和MSG4。
步骤5:【POD1】broker把MSG34封装为一个CK,并返回MSG34给pod6
步骤6:【POD1】服务HANG主,即没有返回返回ACK。
步骤7:【POD2】返回MSG34的ACK,但是此时是被封装为一个ACK消息存储到revive-TOPIC中。
步骤8和9:定时任务PopReviveService定期会处理ACK的消息,和CK集合做合并,从而提交位点。此时MSG12的位点并没有确认,也不知道是否成功消费
步骤10:定时任务PopReviveService#reviveMsgFromCk会把未确认的消息重放到target-RETRY-TOPIC中,等待消费者概率触发重新消费

总结

失败的需要落盘,5.x版本是存到一个RETRY-TOPIC上,如果我们使用4.0版本可以落MySQL。
落盘失败的消息怎么能再次被消费?5.x版本使得不同的消费者的入口逻辑是一样的,所以别的消费者是有概率获得这条消息的。如果我们使用4.0版本,则可以@ScheduleX注解,任何一台机器都有概率获取。注意消费的幂等性。

参考

https://blog.csdn.net/qq_32099833/article/details/135370847

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/560297.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

苹果 IPA 应用部署软件 iMazing 3 Windows 版获 3.0.0.4 Beta 4

在数字化时代,我们的iOS设备已经成为生活中不可或缺的一部分。为了更加高效、便捷地管理这些设备,iMazing 3.0.0.3 应运而生,它以其独特的功能和卓越的性能,为用户带来了前所未有的全新体验。 首先,iMazing 3.0.0.3 提…

集简云数据表新增批量操作功能,一键实现批量触发执行对应自动化流程

在使用数据表时,某些情况下可能希望人工触发自动化流程执行,例如:开发票、提交工单、同步帐套信息等场景。 通过数据表按钮字段,可手动触发执行对应自动化流程,实现将数据推送到其他表单、应用系统,或从其…

C++必修:从C语言到C++的过渡(上)

✨✨ 欢迎大家来到贝蒂大讲堂✨✨ 🎈🎈养成好习惯,先赞后看哦~🎈🎈 所属专栏:C学习 贝蒂的主页:Betty’s blog 1. 什么是C C(c plus plus)是一种计算机高级程序设计语言&…

新型大数据架构之湖仓一体(Lakehouse)架构特性说明——Lakehouse 架构(一)

文章目录 为什么需要新的数据架构?湖仓一体(Lakehouse)——新的大数据架构模式同时具备数仓与数据湖的优点湖仓一体架构存储层计算层 湖仓一体特性单一存储拥有数据仓库的查询性能存算分离开放式架构支持各种数据源类型支持各种使用方式架构简…

csdn的编写教程(官方给的)

自定义的目录标题 欢迎使用Markdown编辑器新的改变功能快捷键合理的创建标题,有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列表创建一个表格设定内容居中、居左、居右SmartyPants 创建一个自定义列表如何创建一个注脚…

ubuntu 16.04.7连不上网的解决方案

首先在编辑选项卡里找到虚拟网络编辑器, 点击更改设置 点击添加网络 点击确定 选择桥接模式,自动后点击应用,最后点击确定即可。

4.20+C语言感想,有趣的思考题,case的省略操作,统计位数,终止循环,break和continue语句, 准备下一篇见。

鹏哥C语言感想 一.高级 这可不是什么煎饼,这种食物叫做蓝莓,俗称苹果。生长在撒哈拉沙漠的雨林地带。因外形酷似企鹅,所以我们又喜欢叫他北极熊。你们这些人,连仙人掌都不知道,就不要乱说他是西瓜好吗?再…

嵌入式4-20

客户端 #include <myhead.h> #define SER_IP "192.168.125.244" #define SER_PORT 8888 typedef struct Node { char username[20];struct sockaddr_in cin;struct Node *next; }Node,*Node_p; typedef struct {int flag;char username[20];char data[1024]…

java中File类和输入输出流的用法

目录 针对文件系统进行操作 针对文件内容进行操作 java针对文件操作可以分为两种&#xff1a;1&#xff09;针对文件系统进行操作&#xff0c;如创建文件&#xff0c;删除文件&#xff0c;创建目录&#xff0c;重命名文件等。 2&#xff09;针对文件内容进行操作&#xff0c…

【webrtc】m98 RoundRobinPacketQueue的优先级处理

m98 代码 PacedSender::EnqueuePackets 的调用者可能是多个地方,所以这个要加锁保护。RoundRobinPacketQueue 本身是没有锁的发现m98和新版本不同,参考:【webrtc】m114自己实现的PrioritizedPacketQueuepush和pop都是RtpPacketToSend 但是实际上,内部是封装为QueuedPacket 处…

Darknet框架优化介绍

一、DarkNet框架简介 1.DarkNet的简介 Darknet是一个完全使用C语言编写的人工智能框架&#xff0c;可以使用CUDA的开源框架。主要应用于图像识别领域。 它具有可移植性好&#xff0c;安装间接&#xff0c;查看源码方便等优势&#xff0c;提供了OpenCV等附加选项&#xff0c;还…

基于SSM+Jsp+Mysql的电子商城系统

开发语言&#xff1a;Java框架&#xff1a;ssm技术&#xff1a;JSPJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09;数据库工具&#xff1a;Navicat11开发软件&#xff1a;eclipse/myeclipse/ideaMaven包…

hackthebox - Redeemer

2024.4.19 TASK 1 Which TCP port is open on the machine? 6379 TASK 2 Which service is running on the port that is open on the machine? redis TASK 3 What type of database is Redis? Choose from the following options: (i) In-memory Database, (ii) Traditiona…

Java -集合-知识点

本文详细介绍了Java中集合的基本概念、常用数据结构和核心特性。通过学习本文&#xff0c;读者可以了解到Java集合框架的核心接口和实现类&#xff0c;掌握各种数据结构在不同场景下的应用方法和优劣势&#xff0c;以及如何使用集合框架提供的方法进行数据操作和处理。同时&…

智慧公厕是如何诞生的?

在城市化进程中&#xff0c;公共卫生设施的建设一直是重要议题之一。而随着科技的不断发展&#xff0c;智慧公厕作为一种创新的解决方案&#xff0c;逐渐成为了现代城市管理的亮点。那么&#xff0c;智慧公厕是如何产生的呢&#xff1f; 一、城市化进程的推动 城市人口的增加和…

[阅读笔记16][Orca-2]Teaching Small Language Models How to Reason

接下来是Orca-2&#xff0c;这篇是微软在23年11月发表的论文&#xff0c;在Orca-1的基础上又进行了一些改进。 作者希望教会Orca-2各种推理策略&#xff0c;例如逐步思考、回忆然后回答、先回忆再推理再回答、直接生成回答等等策略。并且Orca-2应该能针对不同任务应该使用最合适…

使用PHP开发体育赛事直播平台,有这些缺点和优点

"东莞梦幻网络科技"作为体育直播平台开发领域的领导者&#xff0c;选择使用PHP开发体育赛事直播平台的现成源码&#xff0c;为什么会选择该语言&#xff0c;背后的选择理由可以从该技术的优点和缺点中找到答案。 一、优点1、易学易用与快速开发&#xff1a;PHP语言语…

为电路提供参考电压(基准电压) - 齐纳二极管的使用

在电路中通常需要用到参考电压&#xff0c;即提供一个恒定的精确的电压值。比如稳压电路、比较器电路、微控制器的Vref&#xff0c;这些电路都需要提供参考电压。很多厂家都提供了参考电压芯片&#xff0c;不过最简单最省钱的方式是使用齐纳二极管。 齐纳二极管 齐纳二极管也是…

OSI网络七层协议 ——(随手笔记)

1.OSI OSI&#xff08;Open System Interconnect&#xff09;&#xff0c;即开放式系统互连。 一般都叫OSI参考模型&#xff0c;是ISO组织在1985年研究的网络互连模型。该体系结构标准定义了网络互连的七层框架&#xff08;物理层、数据链路层、网络层、传输层、会话层、表示层…

【MATLAB基础绘图第21棒】绘制比例弦图 (Chord Diagram)

MATLAB绘制比例弦图 Chord Diagram 1 简介1.1 弦图简介1.2 比例弦图简介 2 MATLAB绘制比例弦图2.1 数据准备2.2 基本绘制2.3 添加方向箭头2.4 添加绘图间隙2.5 添加刻度2.6 修改标签2.7 颜色设置2.8 弧块及弦属性设置2.8.1 弧块属性设置2.8.2 弦属性设置 2.9 字体设置 参考 1 简…