项目实战之RabbitMQ死信队列应用

🧑‍💻作者名称:DaenCode

🎤作者简介:啥技术都喜欢捣鼓捣鼓,喜欢分享技术、经验、生活。

😎人生感悟:尝尽人生百味,方知世间冷暖。



文章目录

🌟架构图

  1. 死信队列架构图
  2. 本地消息表

🌟application.yml文件

yaml 复制代码
mqconfig:
  #延迟队列,不能被监听消费
  stock_release_delay_queue: stock.release.delay.queue

  #延迟队列的消息过期后转发的队列
  stock_release_queue: stock.release.queue

  #交换机
  stock_event_exchange: stock.event.exchange

  #进入延迟队列的路由key
  stock_release_delay_routing_key: stock.release.delay.routing.key

  #消息过期,进入释放队列的key
  stock_release_routing_key: stock.release.routing.key

  #消息过期时间,毫秒,测试改为15秒
  ttl: 360000

🌟RabbitMQ配置

java 复制代码
@Configuration
@Data
public class RabbitMQConfig {
    /**
     * 交换机
     */
    @Value("${mqconfig.stock_event_exchange}")
    private String eventExchange;


    /**
     * 第一个队列延迟队列,
     */
    @Value("${mqconfig.stock_release_delay_queue}")
    private String stockReleaseDelayQueue;

    /**
     * 第一个队列的路由key
     * 进入队列的路由key
     */
    @Value("${mqconfig.stock_release_delay_routing_key}")
    private String stockReleaseDelayRoutingKey;


    /**
     * 第二个队列,被监听恢复库存的队列
     */
    @Value("${mqconfig.stock_release_queue}")
    private String stockReleaseQueue;

    /**
     * 第二个队列的路由key
     *
     * 即进入死信队列的路由key
     */
    @Value("${mqconfig.stock_release_routing_key}")
    private String stockReleaseRoutingKey;

    /**
     * 过期时间
     */
    @Value("${mqconfig.ttl}")
    private Integer ttl;

    /**
     * 消息转换器
     * @return
     */
    @Bean
    public MessageConverter messageConverter(){
        return new Jackson2JsonMessageConverter();
    }

    /**
     * 创建topic交换机
     * 一个微服务一个交换机
     * @return
     */
    @Bean
    public Exchange stockEventExchange(){
        return new TopicExchange(eventExchange,true,false);
    }

    /**
     * 延迟队列
     * @return
     */
    @Bean
    public Queue stockReleaseDelayQueue(){
        Map<String,Object> args=new HashMap<>();
        args.put("x-message-ttl",ttl);
        args.put("x-dead-letter-routing-key",stockReleaseRoutingKey);
        args.put("x-dead-letter-exchange",eventExchange);
        return new Queue(stockReleaseDelayQueue,true,false,false,args);
    }
    /**
     * 死信队列,用于被监听
     */
    @Bean
    public Queue stockReleaseQueue(){
        return new Queue(stockReleaseQueue,true,false,false);
    }

    /**
     * 死信队列绑定关系
     * @return
     */
    @Bean
    public Binding stockReleaseBinding(){
        return new Binding(stockReleaseQueue,Binding.DestinationType.QUEUE,eventExchange,stockReleaseRoutingKey,null);
    }

    /**
     * 延迟队列绑定关系
     * @return
     */
    @Bean
    public Binding stockReleaseDelayBinding(){
        return new Binding(stockReleaseDelayQueue,Binding.DestinationType.QUEUE,eventExchange,stockReleaseDelayRoutingKey,null);
    }
}

🌟消息发送、消费

  1. 接受到订单服务大哥锁定库存请求时,进行锁定库存消息的发送。
  2. 发送消息的同时,在本地消息表插入记录。
  3. 消息消费时,找订单服务大哥查询订单状态即可。
  4. 根据订单状态,进行后续处理。

🌟写在最后

RabbitMQ项目实战之死信队列应用到此就结束啦!感谢大家的阅读,欢迎大家在评论区进行交流。


相关推荐
黑棠会长10 分钟前
ABP框架09.数据安全与合规:审计日志与实体变更追踪
分布式·安全·架构·c#·abp
珠海西格2 小时前
四可装置如何监测组件衰减与逆变器效率?
大数据·运维·服务器·分布式·能源
仗剑_走天涯4 小时前
Hadoop 安装
大数据·hadoop·分布式
czlczl200209254 小时前
Zookeeper原理
分布式·zookeeper·云原生
weixin199701080166 小时前
《深入浅出:图解淘宝分布式数据库TDDL(及开源替代方案)》
数据库·分布式·开源
bukeyiwanshui6 小时前
Hadoop环境搭建
大数据·hadoop·分布式
白驹过隙不负青春9 小时前
Zookeeper版本升级
分布式·zookeeper·云原生
安审若无9 小时前
【无标题】
中间件·rabbitmq
真上帝的左手9 小时前
12. 消息队列-RabbitMQ-高可用队列详解
分布式·rabbitmq·mq
断春风10 小时前
RabbitMQ在Java中的应用与实践
java·rabbitmq·java-rabbitmq