RabbitMQ发送和接收消息的几种方式

开发 前端
channel.basicQos(0, 1, false):0表示对消息的大小无限制,1表示每次只允许消费一条,false表示该限制不作用于channel。同时,我们采用手工ACK的方式,因为我们配置文件配置了 spring.rabbitmq.listener.simple.acknowledge-mode=manual。

一、发送消息的几种方式

1.1、默认交换机和routingKey----(个人不推荐使用)

    使用默认的交换机exchange或routingKey。

图片图片

调用方法:

图片图片

1.2、使用指定routingKey的方式发送(默认的交换机)

    使用默认的交换机,routingKey必须为quenue队列的名称。

调用方法:

图片图片

案例:

/**
 * @Author yangyalin
 * @Description 测试发送消息(直接使用队列发送,使用默认的交换机) routingKey:即为对列的名称即可
 **/
public void testSendMsg(String message){
    rabbitTemplate.convertAndSend(RabbitMQConvertConfig.TEST_QUEUE,message);
}

1.3、指定交换机和routingKey的方式发送

    使用指定的交换机,若绑定routingKey,必须使用指定的模式;若没有绑定,可设置为""。

调用方法:

图片图片

案例:

public void sendDecreStockMessage(DecreStockFromRabbit decreStockFromRabbit){
    CorrelationData correlationData = new CorrelationData();
    correlationData.setId(decreStockFromRabbit.getMessageId());
  /**
   * exchange:交换机  routingKey:路由键  message:消息体内容   correlationData:消息唯一ID
  **/
    rabbitTemplate.convertAndSend(RabbitMQConvertConfig.ORDER_EXCHANGE,
        RabbitMQConvertConfig.ORDER_ROUTINGKEY, decreStockFromRabbit,correlationData);
}
或:
rabbitTemplate.convertAndSend("test-exchange","",message);

二、接收消息的几种方式

2.1、默认交换机,提前创建好队列(TestDirectQueue)

/**
     * 功能描述:当消费同一个队列的时候,可通过设置实现能则多劳,
     * 消息轮询方式订阅
     * @MethodName: process11
     * @MethodParam: [testMessage]
     * @Return: void
     * @Author: yyalin
     * @CreateDate: 2022/4/9 17:10
     */
    @RabbitListener(queues = "TestDirectQueue")   //监听的队列名称 TestDirectQueue
    public void process11(Map testMessage) throws InterruptedException {
        log.info("消费者收到消息222:" + testMessage.toString());
        Thread.sleep(200);
    }

2.2、默认交换机,自动创建队列(TEST_QUEUE2)

@RabbitListener(queuesToDeclare=@Queue(TopicExchangeConfig.TEST_QUEUE2))
@RabbitHandler
public void receiveTestMsg2(@Payload String str) throws Exception{
    log.info("开始接收消息。。。。。");
    log.info("接收到的消息:"+str);
}

2.3、自动创建交换机和队列----(个人推荐)

    自动创建且交换机和队列绑定,key可指定也可不指定(默认为队列名称)。

/******************方案二:使用注解的方式绑定队列在交换机上*******************/
    @RabbitListener(bindings = @QueueBinding(value=@Queue(name="directQueue"),
            exchange=@Exchange(name="directExchange",type = ExchangeTypes.DIRECT),
            key={"red", "blue"}
    ))    //监听的队列名称 TestDirectQueue
    public void directConsumer(String message) {
        log.info("消费者收到direct消息555  : " + message);
    }


   @RabbitListener(bindings = @QueueBinding(value=@Queue(name="topicQueue2"),
            exchange=@Exchange(name="topicExchange",type = ExchangeTypes.TOPIC,ignoreDeclarationExceptions = "true"),
            key="#.new"
    ))
    public void topicConsumer2(String message) {
        log.info("消费者收到topic消息888  : " + message);
    }

备注:ignoreDeclarationExceptions = "true" : 即使配置出现了错误也不至于整个应用程序都启动失败的情况。

1、channel.basicQos(0, 1, false):0表示对消息的大小无限制,1表示每次只允许消费一条,false表示该限制不作用于channel。

同时,我们采用手工ACK的方式,因为我们配置文件配置了   spring.rabbitmq.listener.simple.acknowledge-mode=manual:

2、channel.basicAck(deliveryTag, false):deliveryTag表示处理的消息条数(一般为1),从heaers中取,false表示不批量ack。

/**
     * 功能描述: 消费端加上手动确认消息被接收
     * @MethodName: process
     * @MethodParam: [message]
     * @Return: void
     * @Author: yyalin
     * @CreateDate: 2022/4/18 19:10
     */
    @RabbitListener(queues = "TestDirectQueue3")    //监听的队列名称 TestDirectQueue
    public void process(String message, Channel channel) throws IOException {
        log.info("DirectReceiver消费者收到消息1  : " + message);
        long msgId=1111L; //消息ID
        try {
            //手动确认消息已消费
            channel.basicAck(msgId,false);
        } catch (IOException e) {
            //把消息失败的消息重新放入到队列
            channel.basicNack(msgId,false,true);
            e.printStackTrace();
        }
    }
责任编辑:武晓燕 来源: 程序猿小杨
相关推荐

2021-06-16 07:02:22

Python方式邮件

2020-07-14 09:58:01

Python开发工具

2021-05-10 15:05:18

消息通信本地网络

2023-05-17 08:16:04

RabbitMQ消息传递

2020-09-14 11:50:21

SpringBootRabbitMQJava

2023-10-13 10:44:35

OC消息发送

2021-12-06 15:02:37

RabbitMQ系统消息

2023-12-04 09:23:49

分布式消息

2021-08-10 09:59:15

RabbitMQ消息微服务

2010-07-20 11:03:45

Telnet会话

2020-10-14 08:36:10

RabbitMQ消息

2022-07-26 20:00:35

场景RabbitMQMQ

2022-08-02 11:27:25

RabbitMQ消息路由

2012-12-24 08:56:15

iOSUnity3D

2021-05-07 16:19:36

异步编程Java线程

2021-01-19 11:56:19

Python开发语言

2010-09-25 14:48:55

SQL连接

2023-10-16 18:39:22

2023-12-18 08:36:39

消息队列微服务开发

2020-03-27 15:10:23

SpringJava框架
点赞
收藏

51CTO技术栈公众号