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