欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 编程资源 > 编程问答 >内容正文

编程问答

RocketMQ的Consumer详解之push和pull模式(长轮询)

发布时间:2024/4/13 编程问答 64 豆豆
生活随笔 收集整理的这篇文章主要介绍了 RocketMQ的Consumer详解之push和pull模式(长轮询) 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

 push和pull模式

在RocketMQ中,消费者有两种模式,一种是push模式,另一种是pull模式。

push模式:客户端与服务端建立连接后,当服务端有消息时,将消息推送到客户端。

pull模式:客户端不断的轮询请求服务端,来获取新的消息。

但在具体实现时,Push和Pull模式都是采用消费端主动拉取的方式,即consumer轮询从broker拉取消息。

区别:

Push方式里,consumer把轮询过程封装了,并注册MessageListener监听器,取到消息后,唤醒MessageListener的consumeMessage()来消费,对用户而言,感觉消息是被推送过来的。

Pull方式里,取消息的过程需要用户自己写,首先通过打算消费的Topic拿到MessageQueue的集合,遍历MessageQueue集合,然后针对每个MessageQueue批量取消息,一次取完后,记录该队列下一次要取的开始offset,直到取完了,再换另一个MessageQueue。

疑问:既然是采用pull方式实现,RocketMQ如何保证消息的实时性呢?

长轮询

RocketMQ中采用了长轮询的方式实现,什么是长轮询呢?

长轮询即是在请求的过程中,若是服务器端数据并没有更新,那么则将这个连接挂起,直到服务器推送新的数据,再返回,然后进入循环周期。

客户端像传统轮询一样从服务端请求数据,服务端会阻塞请求不会立刻返回,直到有数据或超时才返回给客户端,然后关闭连接,客户端处理完响应信息后再向服务器发送新的请求。

 

总结

以上是生活随笔为你收集整理的RocketMQ的Consumer详解之push和pull模式(长轮询)的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。