RabbitMQ 延迟队列,消息延迟推送,图解Janusgraph系列-并发安全

@Bean

public Queue lazyQueue(){

return new Queue(LAZY_QUEUE, true);

}

@Bean

public Binding lazyBinding(){

return BindingBuilder.bind(lazyQueue()).to(lazyExchange()).with(LAZY_KEY);

}

}

我们在 Exchange 的声明中可以设置exchange.setDelayed(true)来开启延迟队列,也可以设置为以下内容传入交换机声明的方法中,因为第一种方式的底层就是通过这种方式来实现的。

//Map<String, Object> pros = new HashMap<>();

//设置交换机支持延迟消息推送

//pros.put(“x-delayed-message”, “topic”);

TopicExchange exchange = new TopicExchange(LAZY_EXCHANGE, true, false, pros);

发送消息时我们需要指定延迟推送的时间,我们这里在发送消息的方法中传入参数 new MessagePostProcessor() 是为了获得 Message对象,因为需要借助 Message对象的api 来设置延迟时间。

import com.anqi.mq.config.MQConfig;

import org.springframework.amqp.AmqpException;

import org.springframework.amqp.core.Message;

import org.springframework.amqp.core.MessageDeliveryMode;

import org.springframework.amqp.core.MessagePostProcessor;

import org.springframework.amqp.rabbit.connection.CorrelationData;

import org.springframework.amqp.rabbit.core.RabbitTemplate;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.stereotype.Component;

import java.util.Date;

@Component

public class MQSender {

@Autowired

private RabbitTemplate rabbitTemplate;

//confirmCallback returnCallback 代码省略,请参照上一篇

public void sendLazy(Object message){

rabbitTemplate.setMandatory(true);

rabbitTemplate.setConfirmCallback(confirmCallback);

rabbitTemplate.setReturnCallback(returnCallback);

//id + 时间戳 全局唯一

CorrelationData correlationData = new CorrelationData(“12345678909”+new Date());

//发送消息时指定 header 延迟时间

rabbitTemplate.convertAndSend(MQConfig.LAZY_EXCHANGE, “lazy.boot”, message,

new MessagePostProcessor() {

@Override

public Message postProcessMessage(Message message) throws AmqpException {

//设置消息持久化

message.getMessageProperties().setDeliveryMode(MessageDeliveryMode.PERSISTENT);

//message.getMessageProperties().setHeader(“x-delay”, “6000”);

message.getMessageProperties().setDelay(6000);

return message;

}

}, correlationData);

}

}

我们可以观察 setDelay(Integer i)底层代码,也是在 header 中设置 x-delay。等同于我们手动设置 header

message.getMessageProperties().setHeader(“x-delay”, “6000”);

/**

  • Set the x-delay header.

  • @param delay the delay.

  • @since 1.6

*/

public void setDelay(Integer delay) {

if (delay == null || delay < 0) {

this.headers.remove(X_DELAY);

}

else {

this.headers.put(X_DELAY, delay);

}

}

消费端进行消费

import com.rabbitmq.client.Channel;

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

img
img

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V:vip1024b 备注Java获取(资料价值较高,非无偿)
img

总结

其他的内容都可以按照路线图里面整理出来的知识点逐一去熟悉,学习,消化,不建议你去看书学习,最好是多看一些视频,把不懂地方反复看,学习了一节视频内容第二天一定要去复习,并总结成思维导图,形成树状知识网络结构,方便日后复习。

这里还有一份很不错的《Java基础核心总结笔记》,特意跟大家分享出来

目录:

部分内容截图:


内容第二天一定要去复习,并总结成思维导图,形成树状知识网络结构,方便日后复习。

这里还有一份很不错的《Java基础核心总结笔记》,特意跟大家分享出来

目录:

[外链图片转存中…(img-OlNjLqsc-1711576155687)]

部分内容截图:

[外链图片转存中…(img-SuJXTYqB-1711576155687)]

[外链图片转存中…(img-AWO34LiT-1711576155688)]

  • 29
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,您的问题是如何发 RabbitMQ 延迟队列消息并处理返回结果,对吗?首先,需要明确 RabbitMQ 延迟队列的概念:延迟队列是一种特殊的队列消息到该队列后不会立即被消费者接收,而是会在一定的时间后才会被消费者接收。 下面是使用 Spring Boot 和 RabbitMQ 实现 RabbitMQ 延迟队列的步骤: 1. 在 RabbitMQ 中创建一个延迟队列,可以通过 RabbitMQ 的插件 rabbitmq_delayed_message_exchange 来实现。具体操作可以参考官方文档。 2. 在 Spring Boot 中配置 RabbitMQ 连接信息和 Exchange。 3. 在发消息的时候,设置消息的过期时间,使得消息被发延迟队列中。 4. 在消费者中,设置监听延迟队列,等待消息被消费。 下面是一个发 RabbitMQ 延迟队列消息的示例代码: ```java // 设置消息过期时间,单位为毫秒 Long expiration = 10000L; // 创建消息 Message message = MessageBuilder.withBody("Hello RabbitMQ Delayed Queue".getBytes()) .setExpiration(expiration.toString().getBytes()) .build(); // 发消息到 Exchange rabbitTemplate.convertAndSend(exchangeName, routingKey, message, new CorrelationData(UUID.randomUUID().toString())); // 处理发失败的消息 rabbitTemplate.setReturnsCallback((message, replyCode, replyText, exchange, routingKey) -> { // 发失败的处理逻辑 }); ``` 在发消息的时候,我们设置了消息的过期时间为 10 秒,即消息会在 10 秒后被消费者接收。同时,我们还设置了发失败的回调函数,以便我们处理发失败的消息。 希望这个回答能够帮助您解决问题。若有不妥之处,还请指正。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值