@PostConstruct在RabbitMQ中的作用

在使用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);


    }
}

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在Ruoyi工程添加RabbitMQ,可以按照以下步骤进行操作: 1. 首先,确保你的Ruoyi工程已经配置好了Maven依赖。在pom.xml文件添加以下依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-amqp</artifactId> </dependency> ``` 2. 在Ruoyi工程的配置文件(application.yml或application.properties)添加RabbitMQ的相关配置信息,包括主机名、端口号、用户名、密码等。例如: ```yaml spring: rabbitmq: host: localhost port: 5672 username: guest password: guest ``` 3. 在Ruoyi工程创建一个消息发送者(Producer)和一个消息接收者(Consumer)。 - 创建消息发送者: ```java import org.springframework.amqp.core.AmqpTemplate; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; @Component public class RabbitMQSender { @Autowired private AmqpTemplate rabbitTemplate; public void send(String message) { rabbitTemplate.convertAndSend("exchangeName", "routingKey", message); } } ``` - 创建消息接收者: ```java import org.springframework.amqp.rabbit.annotation.RabbitListener; import org.springframework.stereotype.Component; @Component public class RabbitMQReceiver { @RabbitListener(queues = "queueName") public void receive(String message) { System.out.println("Received message: " + message); } } ``` 4. 在Ruoyi工程使用消息发送者发送消息,以及使用消息接收者接收消息。 - 在需要发送消息的地方调用消息发送者的send方法: ```java @Autowired private RabbitMQSender rabbitMQSender; public void sendMessage() { rabbitMQSender.send("Hello RabbitMQ!"); } ``` - 在消息接收者处理接收到的消息: ```java @Autowired private RabbitMQReceiver rabbitMQReceiver; @PostConstruct public void init() { rabbitMQReceiver.receive(); } ``` 这样,你就成功地在Ruoyi工程添加了RabbitMQ

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

丁racy

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

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

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

打赏作者

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

抵扣说明:

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

余额充值