@PostConstruct在RabbitMQ中的作用

本文详细介绍了在RabbitMQ中如何使用消息确认机制和回调函数,通过Java代码示例展示了如何设置消息发送者确认及消息发送失败后的回调,同时讲解了消费者端如何处理消息消费确认与异常情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在使用RabbitMQ的时候,使用它的回调函数中用到。

package com.qianfeng.rabbitmq.controller;

import com.qianfeng.rabbitmq.mqconfig.ConfirmCallBack;
import com.qianfeng.rabbitmq.mqconfig.RabbitMQConfig;
import com.qianfeng.rabbitmq.mqconfig.ReturnCallBack;
import org.springframework.amqp.rabbit.connection.CorrelationData;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import javax.annotation.PostConstruct;
import javax.annotation.Resource;

/**
 * @author lh
 * @date 2019/7/23 15:52
 */

@RestController
public class SendMessageController {
    @Resource
    RabbitTemplate rabbitTemplate;

    @RequestMapping("/sendMessage/{msg1}")
    String sendMessage(@PathVariable("msg1") String msg1) throws Exception {

        for (int x = 0; x < 1; x++) {
            rabbitTemplate.convertAndSend(RabbitMQConfig.CQ_SHIQIAOPU_JAVA_DIRECT_EXECHANGE, RabbitMQConfig.CQ_SHIQIAOPU_JAVA_QUEUE2, "张三要开始减去账户的钱了"+x, new CorrelationData("张三要开始减去账户的钱了" + x));
        }
        return msg1;
    }

    // 在我们的sevlet构造函数创建之后,执行
    @PostConstruct
    public void messageConfirmCallBack() {
        rabbitTemplate.setConfirmCallback(new ConfirmCallBack());
        rabbitTemplate.setReturnCallback(new ReturnCallBack());
    }


}

从Java EE5规范开始,Servlet中增加了两个影响Servlet生命周期的注解,@PostConstruct和@PreDestroy,这两个注解被用来修饰一个非静态的void()方法。

被@PostConstruct修饰的方法会在服务器加载Servlet的时候运行,并且只会被服务器执行一次。PostConstruct在构造函数之后执行,init()方法之前执行。PreDestroy()方法在destroy()方法知性之后执行

在使用回调函数前要在配置(yml或bean中)开启回调

server:
  port: 80

spring:
  rabbitmq:
    port: 5672  #rabbitMQ
    host: 192.168.36.139
    virtual-host: /  #虚拟主机路径
    username: qianfeng
    password: java
    publisher-confirms: true  #要手动开启消息发送者的确认消息
    publisher-returns: true #这个是消息发送失败之后的回调开关,默认是false

在消费者端,返回异常就是让RabbitMQ重发

package com.qianfeng.consumer2;

import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.stereotype.Service;

/**
 * @author lh
 * @date 2019/7/23 16:26
 */
@Service
public class Message2ServiceImpl {

    @RabbitListener(queues = RabbitMQConfig.CQ_SHIQIAOPU_JAVA_QUEUE2)
    void dealMessage(String msg) throws Exception {
        // 第一种情况,消费者正常正确的把消息消费了,告诉RabbitMQ成功了,请你删除消息
//        没有抛出异常,系统自动确认消费成功!

        // 第二种情况,消费者在执行业务代码的时候,出错。导致没有能够正确消费消息,这个时候要告诉RabbitMQ重发消息

//        如果抛出异常,系统自动认为消费失败!

        System.err.println("消费者2收到的消息是:" + msg);


    }
}

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

丁racy

感谢各位兄弟的打赏!O(∩_∩

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值