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

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

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

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

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

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

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

你可能感兴趣的文章
Node入门之创建第一个HelloNode
查看>>
Node出错导致运行崩溃的解决方案
查看>>
Node提示:error code Z_BUF_ERROR,error error -5,error zlib:unexpected end of file
查看>>
NOIp2005 过河
查看>>
NOPI读取Excel
查看>>
NoSQL&MongoDB
查看>>
NotImplementedError: Cannot copy out of meta tensor; no data! Please use torch.nn.Module.to_empty()
查看>>
npm install报错,证书验证失败unable to get local issuer certificate
查看>>
npm run build 失败Compiler server unexpectedly exited with code: null and signal: SIGBUS
查看>>
npm run build报Cannot find module错误的解决方法
查看>>
npm run build部署到云服务器中的Nginx(图文配置)
查看>>
npm WARN deprecated core-js@2.6.12 core-js@<3.3 is no longer maintained and not recommended for usa
查看>>
npm切换到淘宝源
查看>>
npm前端包管理工具简介---npm工作笔记001
查看>>
npm和yarn清理缓存命令
查看>>
npm和yarn的使用对比
查看>>
npm报错unable to access ‘https://github.com/sohee-lee7/Squire.git/‘
查看>>
npm的问题:config global `--global`, `--local` are deprecated. Use `--location=global` instead 的解决办法
查看>>
npm错误Error: Cannot find module ‘postcss-loader‘
查看>>
NPOI之Excel——合并单元格、设置样式、输入公式
查看>>