为了账号安全,请及时绑定邮箱和手机立即绑定

java rocketmq 生产者如何取得消费者的消费结果

java rocketmq 生产者如何取得消费者的消费结果

精慕HU 2018-07-09 11:23:22
比如说:我项目的服务接口,需要给调用者返回一个是否成功结果。因为可能并发量比较大,用rocketmq来流量削峰。我将生产者写入到接口中,每次调这个接口,生产者发送消息,消费者监听,并处理接口的实际业务。但是如何返回给生产者处理结果?我没找到具体代码方法。还是说我上面做的方法,是不可行的?求解答
查看完整描述

1 回答

?
白猪掌柜的

TA贡献1893条经验 获得超10个赞

首先要明白消息队列是用于什么场景的;
绝大部分用于削峰和解耦,也有用于处理分布式事务!
然后再想想削峰的目的是什么,削峰是用于当应用处理不过来过大的并发请求时,将请求存于队列中,用单个或多个消费者来处理请求!

这时候想要拿到请求怎么办呢?
1.每个消费者处理完成请求,再发送消息到消息队列中,你的生产者那方再实现消费者来消费这些处理结果信息;
然后处理你的逻辑!
2.将处理结果存于缓存等高性能组件中,通过轮询的方式获取任务处理结果

不管什么方式,你的请求方都应该是在你将请求消息发到队列后立即返回的!消息结果可以用推送的方式告知(移动端的话),也可以让请求方每个几秒轮询一次
处理结果;

希望对你有帮助...


查看完整回答
2 反对 回复 2018-07-26
  • 1 回答
  • 1 关注
  • 3589 浏览

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号