java监控队列_java-Spring Rabbit监听输出队列或接收

本文探讨了在Spring应用中使用RabbitMQ时,两种消息发送方式的性能比较:同步sendWithResult与异步convertSend。作者建议采用异步模式,避免阻塞发送线程,以提高在高负载下的效率和稳定性。
摘要由CSDN通过智能技术生成

我正在开发具有Rabbitmq支持的应用程序.因此,我有一个消费者和一个生产者.我需要在两种方法之间做出决定,如何在两者之间建立通信.

第一种方式

public void send(){

//send to consumer and forget

rabbitTemplate.convertAndSend("","routing-key",my object);

//waiting for output queue and messages from consumer

while(true){

//receive something.

if(corellationID==what we need){

//do what we need

break;

}

}

}

第二种方式

public void send(){

//send to consumer and wait for result

Object o=rabbitTemplate.convertSendAndReceive("","routing-key",my object);

}

哪种方法在高负载下会更快速,更稳定地工作?也许还有另一种更有效的方法可以做到这一点.谢谢

解决方法:

与第一种方法一样,第二种方法必须实现第二种方法已经完成的工作:

>创建相关ID

>维护地图

>从答复队列出队消息

>将回复消息与生产者相关联

> …

最有效的方法是没有等待回复的线程.因此以异步方式工作:发送消息的线程可能不是接收答复的线程. Have a look at the documentation

标签:rabbitmq,spring,java

来源: https://codeday.me/bug/20191120/2044004.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值