博客
关于我
RocketMq 消费消息的两种方式 pull 和 push
阅读量:762 次
发布时间:2019-03-23

本文共 529 字,大约阅读时间需要 1 分钟。

在RocketMQ中,获取消息有两种主要方式:拉(Pull)和推(Push)。两种方式各有优缺点,适用于不同的场景,因此理解它们的区别和使用条件非常重要。

拉(Pull)方式:消费者主动连接到Broker,通过指定Topic获取消息。在拉取过程中,消费者需要处理大量的逻辑,包括遍历消息队列、批量取消息、记录偏移量等。这一过程可能需要复杂的循环结构和线程同步机制。这种方式的好处是能确保消息的可靠性和高可用性,因为消费者可以主动拉取,避免消息积压。但它的实现相对复杂,需要处理失败重试、消息分批处理以及可能的网络问题。

推(Push)方式:Broker主动向消费者发送消息,当消息到达特定的Topic时,消费者接收并处理。这一流程通常由Broker中的监听器(MessageListener)管理,相对于拉取方式,推方式更对称,用户感知上更像是消息被推送而来。这种方式适合处理流式数据或需要实时响应的场景,因为它减少了消费者的主动性,不过也可能因为响应不及时导致消息积压。

在实际应用中,选择拉还是推取决于具体需求。拉取方式适合需要确保所有消息处理且高度可靠的场景,而推取则更适合需要快速响应和低延迟的应用。两者也可以结合使用,以平衡系统性能和消息处理效率。

转载地址:http://fmozk.baihongyu.com/

你可能感兴趣的文章
OS模块
查看>>
OS第2章 —— 进程
查看>>
OS第3章 —— 进程调度和死锁
查看>>
OS第5章
查看>>
OTA测试
查看>>
Outlook 2010 Inside Out
查看>>
overlay(VLAN,VxLAN)、underlay网络、大二层概述
查看>>
OWASP漏洞原理<最基础的数据库 第二课>
查看>>
OWL本体语言
查看>>
P with Spacy:自定义文本分类管道
查看>>
P1364 医院设置
查看>>
P2260 [清华集训2012]模积和
查看>>
SpringBoot中集成influxdb-java实现连接并操作Windows上安装配置的influxDB(时序数据库)
查看>>
SpringBoot中集成eclipse.paho.client.mqttv3实现mqtt客户端并支持断线重连、线程池高并发改造、存储入库mqsql和redis示例业务流程,附资源下载
查看>>
Padding
查看>>
paddlehub安装及对口罩检测
查看>>
SpringBoot中集成Actuator实现监控系统运行状态
查看>>
paddle的两阶段基础算法基础
查看>>
Page Object模式:为什么它是Web自动化测试的必备工具
查看>>
SpringBoot中重写addCorsMapping解决跨域以及提示list them explicitly or consider using “allowedOriginPatterns“ in
查看>>