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

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

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

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

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

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

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

你可能感兴趣的文章
Oracle 12c中的MGMTDB
查看>>
Oracle 12c安装报错Installation failed to access the temporary location(无法访问临时位置)...
查看>>
Oracle 9i数据库管理教程
查看>>
ORACLE Active dataguard 一个latch: row cache objects BUG
查看>>
oracle avg、count、max、min、sum、having、any、all、nvl的用法
查看>>
Oracle BEQ方式连接配置
查看>>
oracle Blob保存方式,oracle 存储过程操作blob
查看>>
Oracle BMW Racing sailing vessel帆船图
查看>>
ORACLE Bug 4431215 引发的血案—原因分析篇
查看>>
Oracle cmd乱码
查看>>
Oracle Corp甲骨文公司推出Oracle NoSQL数据库2.0版
查看>>
Oracle DBA课程系列笔记(20)
查看>>
oracle dblink 创建使用 垮库转移数据
查看>>
oracle dblink结合同义词的用法 PLS-00352:无法访问另一数据库
查看>>
Oracle dbms_job.submit参数错误导致问题(ora-12011 无法执行1作业)
查看>>
oracle dg switchover,DG Switchover fails
查看>>
Oracle E-Business Suite软件 任意文件上传漏洞(CVE-2022-21587)
查看>>
Oracle EBS OPM 发放生产批
查看>>
Oracle EBS-SQL (BOM-15):检查多层BOM(含common BOM).sql
查看>>
Oracle EBS环境下查找数据源(OAF篇)
查看>>