MQ的消费模式-消息是推还是拉
文章目录
- 概述
- RocketMQ默认push
- RabbitMQ默认push
- Kafka默认拉Pull
- ActiveMQ默认push
概述
MQ的消费模式可以大致分为两种,一种是推Push,一种是拉Pull
Push是服务端主动推送消息给客户端,Pull是客户端需要主动到服务端轮询获取数据。
推优点是及时性较好,但如果客户端没有做好流控,一旦服务端推送大量消息到客户端时,就会导致客户端消息堆积甚至崩溃。
拉优点是客户端可以依据自己的消费能力进行消费,但是频繁拉取会给服务端造成压力,并且可能会导致消息消费不及时。
在消息队列系统中,Kafka、RabbitMQ、ActiveMQ和RocketMQ都支持推模式(Push)和拉模式(Pull)两种消息消费方式。但是它们在默认行为和主要特点上有所不同:
- Kafka:
○ 默认行为:Kafka 使用拉模式(Pull)作为默认的消息消费方式。消费者需要主动从 Kafka Broker 拉取消息。
○ 主要特点:Kafka 提供高吞吐量、持久性、分布式、可扩展的消息传递。消费者可以自主控制消息的消费进度。 - RabbitMQ:
○ 默认行为:RabbitMQ 使用推模式(Push)作为默认的消息消费方式。Broker 主动推送消息给消费者。
○ 主要特点:RabbitMQ 提供灵活的消息路由和多种交换机类型,支持广泛的消息协议。它更适合用于实时性要求较高的场景。 - ActiveMQ:
○ 默认行为:ActiveMQ 支持推模式(Push)和拉模式(Pull),具体取决于消费者的配置。通过消息监听器实现推模式,通过 JMS API 实现拉模式。
○ 主要特点:ActiveMQ 是一个功能丰富的开源消息中间件,支持广泛的消息协议和高级特性,如事务性消息和消息持久化。 - RocketMQ:
○ 默认行为:RocketMQ 使用推模式(Push)作为默认的消息消费方式。Broker 主动推送消息给消费者。
○ 主要特点:RocketMQ 是一个高吞吐量、低延迟、高可靠性和可伸缩性的分布式消息队列系统。它在支持海量消息堆积和数据复制方面表现出色。
需要注意的是,以上消息队列系统都可以通过配置或编程来切换消费模式,以满足具体的业务需求。选择合适的消息消费方式取决于应用程序的实时性要求、处理能力以及对消息传输的可控性需求。
RocketMQ默认push
RocketMQ 支持两种消费消息的方式:推模式(Push)和拉模式(Pull)。
- 推模式(Push):
在推模式下,消费者向 Broker 注册监听器,当有消息到达时,Broker 主动推送消息给消费者。消费者只需要注册消息监听器,并在监听器中处理接收到的消息即可。 - 拉模式(Pull):
在拉模式下,消费者需要主动向 Broker 发起请求,从指定的队列中拉取消息。消费者需要定时轮询 Broker,获取待消费的消息并进行处理。消费者可以控制拉取消息的频率和数量。
在 RocketMQ 中,消费者默认使用推模式来消费消息。但是也可以通过设置消费者的消费模式为 Pull 来切换到拉模式。
RocketMQ的push模式其实底层的实现还是基于pull实现的,我们介绍过长轮询,其实RocketMQ的push就是通过长轮询来实现的。
总的来说,RocketMQ 的消息消费既支持推模式又支持拉模式,可以根据实际需求选择合适的消费方式。
RabbitMQ默认push
在 RabbitMQ 中,消息消费是基于推模式(Push)实现的。当消费者注册了队列,并设置了消息监听器时,RabbitMQ 会主动推送消息给消费者进行处理。消费者不需要主动轮询或拉取消息,而是由 RabbitMQ 主动将消息推送给已注册的消费者。
这种推模式使得 RabbitMQ 在消息传递方面表现出色,能够及时地将消息传递给消费者。消费者只需关注消息到达时的处理逻辑,而不必担心消息的拉取和管理问题。
总的来说,在 RabbitMQ 中,消息是通过推模式推送给消费者的,消费者只需要注册消息监听器,当有消息到达时就会触发监听器对消息进行处理。
Kafka默认拉Pull
在 Kafka 中,消息消费是基于拉模式(Pull)实现的。消费者需要主动向 Kafka Broker 发起拉取消息的请求,并从指定的主题(topic)中获取消息。消费者可以控制拉取消息的频率、数量以及处理逻辑。
Kafka 的拉取模式使得消费者可以根据自身的处理能力和需求来控制消息的消费速率,可以按照自己的节奏进行消息处理,避免了推送模式下可能出现的消息堆积和处理不及时的情况。
总的来说,在 Kafka 中,消息是通过拉取模式由消费者主动从 Broker 拉取的,消费者可以根据需要自主控制消息的拉取和处理过程。
ActiveMQ默认push
在 ActiveMQ 中,消息消费通常是基于推模式(Push)实现的,类似于 RabbitMQ。当消费者注册了消息监听器并订阅了某个队列或主题时,ActiveMQ 会主动将消息推送给消费者进行处理。消费者无需主动拉取消息,而是等待 ActiveMQ 主动通知并传递消息。
通过消息监听器实现的推模式消费,在 ActiveMQ 中是比较常见和典型的方式。消费者只需关注消息到达时的处理逻辑,而不需要关心消息的拉取和管理细节,简化了消息消费的编程模型。
总的来说,在 ActiveMQ 中,消息消费是通过推模式实现的,消费者注册监听器后,ActiveMQ 主动将消息推送给消费者,消费者只需处理接收到的消息即可。
相关文章:
MQ的消费模式-消息是推还是拉
文章目录 概述RocketMQ默认pushRabbitMQ默认pushKafka默认拉PullActiveMQ默认push 概述 MQ的消费模式可以大致分为两种,一种是推Push,一种是拉Pull Push是服务端主动推送消息给客户端,Pull是客户端需要主动到服务端轮询获取数据。 推优点是及…...

一个平台满足你对测试工具的所有需求
背景 目前,测试人员普遍使用的测试工具有Postman、JMeter等,但这些工具都存在一定的局限性。例如,Postman缺少对API性能测试方面的支持,而JMeter则缺乏一个整合测试报告、测试脚本的统一管理系统以及UI测试功能。 RunnerGo是什么…...
【C语言】【字符串函数】【超详解】【上】!!!
前言: 在学习C语言的过程中,字符串、字符数组等对新手来说总是会有疏忽,在已有的库函数中,我们平时用到最多的就是关于字符串的函数,今天我们就来详细学习字符串函数的相关内容。 下面我们就开始讲解字符串函数&#x…...

算法沉淀——动态规划之其它背包问题与卡特兰数(leetcode真题剖析)
算法沉淀——动态规划之其它背包问题与卡特兰数 二维费用的背包问题01.一和零02.盈利计划 似包非包组合总和 Ⅳ 卡特兰数不同的二叉搜索树 二维费用的背包问题 01.一和零 题目链接:https://leetcode.cn/problems/ones-and-zeroes/ 给你一个二进制字符串数组 strs…...

selenium中ChromeDriver配置,一把过,并且教你伪装
最近正值毕业季,我之前不是写了个问卷星代码嘛,昨晚上有人凌晨1点加我,问我相关内容。 由于我之前C盘重装了一下,导致我很多东西空有其表,实际不能用,借此机会,向大家编写ChromeDriver配置&…...

vue3 + vite 项目可以使用纯Js开发吗?
答案:可以 创建项目: 按照链接参考或者按官方: webstorm 创建vue3 vite 项目-CSDN博客 项目目录 tsconfig.json 配置允许js allowJs指定是否编译js文件,在任意文件当中,如果我们模块使用js写的,那么我们需要 将all…...

Java EE之线程安全问题
一.啥是线程安全问题 有些代码,在单个线程执行时完全正确,但同样的代码让多个线程同时执行,就会出现bug。例如以下代码: 给定一个变量count,让线程t1 t2分别自增5000次,然后进行打印,按理说co…...

掌握Nodejs高级图片压缩技巧提升web优化
掌握Nodejs高级图片压缩技巧提升web优化 在当今的数字时代,图像在网络开发中发挥着至关重要的作用。它们增强视觉吸引力、传达信息并吸引用户。然而,高质量的图像通常有一个显着的缺点——较大的文件大小会减慢网页加载时间。为了应对这一挑战并确保快速加载网站,掌握 Node…...

C++初阶 类(上)
目录 1. 什么是类 2. 如何定义出一个类 3. 类的访问限定符 4. 类的作用域 5. 类的实例化 6. 类的大小 7. this指针 1.this指针的引出 2. this指针的特性 8. 面试题 1. 什么是类 在C语言中,不同类型的数据集合体是结构体。为了方便管理结构体,我…...

图片速览 BitNet: 1-bit LLM
输入数据 模型使用absmax 量化方法进行b比特量化,将输入量化到 [ − Q b , Q b ] ( Q b 2 b − 1 ) \left[-Q_{b},Q_{b}\right](Q_{b}2^{b-1}) [−Qb,Qb](Qb2b−1) x ~ Q u a n t ( x ) C l i p ( x Q b γ , − Q b ϵ , Q b − ϵ ) , Clip ( x , a , b ) ma…...
金融基础——拨备前利润和拨备后利润介绍
一、简介 拨备前利润(PreProvision Operating Profit,也就是PPOP)和拨备后利润的主要区别在于是否扣除减值准备金、是否遵循保守性原则以及显示的利润数值不同。 拨备前利润。指在计算利润时没有扣除减值准备金的利润,它等于税前…...

网络编程作业day7
作业项目:基于UDP的聊天室 服务器代码: #include <myhead.h>//定义客户信息结构体 typedef struct magtye {char type; //消息类型char name[100]; //客户姓名char text[1024]; //客户发送聊天信息 }msg_t;//定义结构体存储…...
【Vision Pro杀手级应用】3D音乐会/演唱会,非VR视频播放的形式,而是实实在在的明星“全息”形象,在你的面前表演
核心内容形式:体积视频 参考对标案例深度解读: 体积视频,这一全新的内容形式,正在引领我们进入一个前所未有的四维体验时代。它将传统的演艺形式推向了新的高度,让我们能够更加深入地沉浸在虚拟世界中,感受前所未有的视听盛宴。 在这一领域,有一个引人注目的案例,那…...

变频器学习
西门子变频器 SINAMICS V20 入门级变频器 SINAMICS G120C...

Linux Ubuntu系统安装MySQL并实现公网连接本地数据库【内网穿透】
文章目录 前言1 .安装Docker2. 使用Docker拉取MySQL镜像3. 创建并启动MySQL容器4. 本地连接测试4.1 安装MySQL图形化界面工具4.2 使用MySQL Workbench连接测试 5. 公网远程访问本地MySQL5.1 内网穿透工具安装5.2 创建远程连接公网地址5.3 使用固定TCP地址远程访问 前言 本文主…...
0048__Unix传奇
Unix传奇 (上篇)_unix传奇(上篇)-CSDN博客 Unix传奇 (下篇)-CSDN博客 Unix现状与未来——CSDN对我的采访_nuix邮件系统行业地位-CSDN博客...

蓝桥杯-排序
数组排序 Arrays.sort(int[] a) 这种形式是对一个数组的所有元素进行排序,并且时按从小到大的顺序。 package Work;import java.util.*;public class Imcomplete {public static void main(String args[]) {int arr[]new int [] {1,324,4,5,7,2};Arrays.sort(arr)…...

计算机设计大赛 深度学习的视频多目标跟踪实现
文章目录 1 前言2 先上成果3 多目标跟踪的两种方法3.1 方法13.2 方法2 4 Tracking By Detecting的跟踪过程4.1 存在的问题4.2 基于轨迹预测的跟踪方式 5 训练代码6 最后 1 前言 🔥 优质竞赛项目系列,今天要分享的是 基于深度学习的视频多目标跟踪实现 …...
高性能JSON框架之FastJson的简单使用
高性能JSON框架之FastJson的简单使用、 1.前言 1.1.FastJson的介绍: JSON协议使用方便,越来越流行,JSON的处理器有很多,这里我介绍一下FastJson,FastJson是阿里的开源框架,被不少企业使用,是一个极其优秀的Json框架,Github地址: FastJson 1.2.FastJson的特点: 1.F…...
★判断素数的几种方法(由易到难,由慢到快)
素数的定义: 素数,又称为质数,指的是“大于1的整数中,只能被1和这个数本身整除的数”。换句话说,素数是只有两个正约数(1和本身)的自然数。素数在数论中有着重要的地位,且素数的个数…...

接口测试中缓存处理策略
在接口测试中,缓存处理策略是一个关键环节,直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性,避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明: 一、缓存处理的核…...

C++实现分布式网络通信框架RPC(3)--rpc调用端
目录 一、前言 二、UserServiceRpc_Stub 三、 CallMethod方法的重写 头文件 实现 四、rpc调用端的调用 实现 五、 google::protobuf::RpcController *controller 头文件 实现 六、总结 一、前言 在前边的文章中,我们已经大致实现了rpc服务端的各项功能代…...

智能仓储的未来:自动化、AI与数据分析如何重塑物流中心
当仓库学会“思考”,物流的终极形态正在诞生 想象这样的场景: 凌晨3点,某物流中心灯火通明却空无一人。AGV机器人集群根据实时订单动态规划路径;AI视觉系统在0.1秒内扫描包裹信息;数字孪生平台正模拟次日峰值流量压力…...
css3笔记 (1) 自用
outline: none 用于移除元素获得焦点时默认的轮廓线 broder:0 用于移除边框 font-size:0 用于设置字体不显示 list-style: none 消除<li> 标签默认样式 margin: xx auto 版心居中 width:100% 通栏 vertical-align 作用于行内元素 / 表格单元格ÿ…...

学习STC51单片机32(芯片为STC89C52RCRC)OLED显示屏2
每日一言 今天的每一份坚持,都是在为未来积攒底气。 案例:OLED显示一个A 这边观察到一个点,怎么雪花了就是都是乱七八糟的占满了屏幕。。 解释 : 如果代码里信号切换太快(比如 SDA 刚变,SCL 立刻变&#…...

力扣热题100 k个一组反转链表题解
题目: 代码: func reverseKGroup(head *ListNode, k int) *ListNode {cur : headfor i : 0; i < k; i {if cur nil {return head}cur cur.Next}newHead : reverse(head, cur)head.Next reverseKGroup(cur, k)return newHead }func reverse(start, end *ListNode) *ListN…...
微服务通信安全:深入解析mTLS的原理与实践
🔥「炎码工坊」技术弹药已装填! 点击关注 → 解锁工业级干货【工具实测|项目避坑|源码燃烧指南】 一、引言:微服务时代的通信安全挑战 随着云原生和微服务架构的普及,服务间的通信安全成为系统设计的核心议题。传统的单体架构中&…...

第一篇:Liunx环境下搭建PaddlePaddle 3.0基础环境(Liunx Centos8.5安装Python3.10+pip3.10)
第一篇:Liunx环境下搭建PaddlePaddle 3.0基础环境(Liunx Centos8.5安装Python3.10pip3.10) 一:前言二:安装编译依赖二:安装Python3.10三:安装PIP3.10四:安装Paddlepaddle基础框架4.1…...

篇章二 论坛系统——系统设计
目录 2.系统设计 2.1 技术选型 2.2 设计数据库结构 2.2.1 数据库实体 1. 数据库设计 1.1 数据库名: forum db 1.2 表的设计 1.3 编写SQL 2.系统设计 2.1 技术选型 2.2 设计数据库结构 2.2.1 数据库实体 通过需求分析获得概念类并结合业务实现过程中的技术需要&#x…...
webpack面试题
面试题:webpack介绍和简单使用 一、webpack(模块化打包工具)1. webpack是把项目当作一个整体,通过给定的一个主文件,webpack将从这个主文件开始找到你项目当中的所有依赖文件,使用loaders来处理它们&#x…...