RabbitMQ中Direct交换机的用法

前言:比如我们的支付完成之后需要进行修改支付状态还要完成短信通知用户需要同时并发两条指令我们可以使用direct交换机进行指定两个不同的业务去完成这两件事

比如我们现在有direct.queue1/direct.queue2两个消息队列,一个direct交换机

我们创建完成两个队列之后需要将交换机进行绑定到对应的队列,绑定时我们需要将key写进去,因为要根据不同的key找到指定的队列去完成不同的消息业务

使用java操作

消费者监听代码

    //使用direct交换机进行消息发送
    @RabbitListener(queues = "direct.queue1")
    public void listenDirectQueue1(String msg) throws InterruptedException {
        System.out.println("消费者收到DirectQueue11111111的消息:"+msg);
        Thread.sleep(20);
    }
    @RabbitListener(queues = "direct.queue2")
    public void listenDirectQueue2(String msg) throws InterruptedException {
        System.out.println("消费者收到DirectQueue2222222222222的消息:"+msg);
        Thread.sleep(200);
    }

发送者代码

    //使用Direct交换机进行消息转发
    @Test
    void testDirect() {
        String exchangeName = "hmall.direct";
        String msg = "blue";
        rabbitTemplate.convertAndSend(exchangeName, "blue",msg);
    }
相关推荐
陶逗逗(打怪升级版)1 小时前
Hadoop集群搭建
大数据·hadoop·分布式
oNuoyi1 小时前
定位线上同步锁仍然重复扣费的Bug定位及Redis分布式锁解决方案
java·spring boot·redis·分布式
小的~~3 小时前
大数据面试题之Spark(6)
大数据·分布式·spark
小的~~3 小时前
大数据面试题之Spark(3)
大数据·分布式·spark
烦 啊3 小时前
kafka 消费者
分布式·kafka
不学会Ⅳ6 小时前
Kafka-Produce客户端源码流程
分布式·kafka·php
听忆.7 小时前
RabbitMQ消息可靠性等机制详解(精细版三)
java·开发语言·spring boot·后端·spring·java-ee·rabbitmq
吃货智9 小时前
Kafka搭建(集群版)
分布式·kafka
赫萝的红苹果9 小时前
基于Redisson实现分布式锁
java·spring boot·分布式
Java追光着11 小时前
谷粒商城笔记-03-分布式基础概念
笔记·分布式·谷粒商城