使用RabbitMQ實(shí)現(xiàn)延時(shí)消息自動(dòng)取消的案例詳解
一、流程圖

二、導(dǎo)包
<!--消息隊(duì)列 AMQP依賴,包含RabbitMQ-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-amqp</artifactId>
</dependency>三、配置文件
#消息隊(duì)列
spring:
rabbitmq:
host: 192.168.88.130
port: 5672
virtual-host: my_vhost #使用的虛擬主機(jī)
username: root
password: root
listener:
simple:
acknowledge-mode: manual #開(kāi)啟手動(dòng)應(yīng)答四、配置類
import org.springframework.amqp.core.*;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import java.util.HashMap;
import java.util.Map;
@Configuration
public class RabbitMQConfig {
/**
* 訂單交換機(jī)
*/
public static final String ORDER_EXCHANGE = "order_exchange";
/**
* 訂單隊(duì)列
*/
public static final String ORDER_QUEUE = "order_queue";
/**
* 訂單路由鍵
*/
public static final String ORDER_ROUTING = "order_routing";
/**
* 死信交換機(jī)
*/
public static final String ORDER_DEAD_EXCHANGE = "order_dead_exchange";
/**
* 死信隊(duì)列
*/
public static final String ORDER_DEAD_QUEUE = "order_dead_queue";
/**
* 死信路由鍵
*/
public static final String ORDER_DEAD_ROUTING = "order_dead_routing";
/**
* 訂單交換機(jī)
*/
@Bean("orderExchange")
public Exchange getOrderExchange() {
return new DirectExchange(ORDER_EXCHANGE);
}
/**
* 訂單隊(duì)列
*/
@Bean("orderQueue")
public Queue getOrderQueue() {
Map<String, Object> map = new HashMap<>(3);
map.put("x-dead-letter-exchange", ORDER_DEAD_EXCHANGE);//死信交換機(jī)
map.put("x-dead-letter-routing-key", ORDER_DEAD_ROUTING);//死信路由鍵
map.put("x-message-ttl", 1000 * 60 * 15);//隊(duì)列過(guò)期時(shí)間
return QueueBuilder
.durable(ORDER_QUEUE)
.withArguments(map)
.build();
}
/**
* 將訂單交換機(jī)與訂單隊(duì)列綁定
*/
@Bean
Binding orderExchangeBindingOrder(@Qualifier("orderExchange") Exchange exchange,
@Qualifier("orderQueue") Queue queue) {
return BindingBuilder.bind(queue).to(exchange).with(ORDER_ROUTING).noargs();
}
/**
* 死信交換機(jī)
*/
@Bean("orderDeadExchange")
public Exchange getOrderDeadExchange() {
return new DirectExchange(ORDER_DEAD_EXCHANGE);
}
/**
* 死信隊(duì)列
*/
@Bean("orderDeadQueue")
public Queue getOrderDeadQueue() {
return new Queue(
ORDER_DEAD_QUEUE,//隊(duì)列名
true,//是否持久化
false,//是否具有排他性,只在首次聲明時(shí)可見(jiàn),不允許其他用戶訪問(wèn),連接斷開(kāi)時(shí)自動(dòng)刪除
false,//是否自動(dòng)刪除,經(jīng)歷過(guò)至少一次連接后,所有消費(fèi)者都斷開(kāi)了連接,此隊(duì)列會(huì)自動(dòng)刪除
null
);
}
/**
* 將死信交換機(jī)與死信隊(duì)列綁定
*/
@Bean
Binding deadExchangeBindingDeadQueue(@Qualifier("orderDeadExchange") Exchange exchange,
@Qualifier("orderDeadQueue") Queue queue) {
return BindingBuilder.bind(queue).to(exchange).with(ORDER_DEAD_ROUTING).noargs();
}
}五、發(fā)送消息的類
import com.sky.configuration.RabbitMQConfig;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.beans.factory.annotation.Autowired;
/**
* 消息隊(duì)列發(fā)送消息
*/
@Component
public class SendRabbitMQ {
@Autowired
private RabbitTemplate rabbitTemplate;
/**
* @param orderId 15分鐘后要檢查的訂單編號(hào)
*/
public void sendDelayOrder(Long orderId) {
rabbitTemplate.convertAndSend(
RabbitMQConfig.ORDER_EXCHANGE,//訂單交換機(jī)
RabbitMQConfig.ORDER_ROUTING,//訂單路由鍵
orderId//要取消的訂單編號(hào)
);
}
}六、接收消息的類
import com.rabbitmq.client.Channel;
import com.sky.configuration.RabbitMQConfig;
import com.sky.mapper.OrderMapper;
import org.springframework.amqp.core.Message;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
/**
* 消息隊(duì)列接收消息
*/
@Component
public class ReceiveRabbitMQ {
@Autowired
private OrderMapper orderMapper;
/**
* @param orderId 要取消的訂單的編號(hào)
* @param msg 包含了要回復(fù)的隊(duì)列
* @param channel 有回復(fù)功能的參數(shù)
*/
@RabbitListener(queues = RabbitMQConfig.ORDER_DEAD_QUEUE)
public void ReceiveDeadOrder(Long orderId, Channel channel, Message msg) throws IOException {
orderMapper.delCancelOrder(orderId);//查詢數(shù)據(jù)庫(kù),訂單是否付款,未付款:改為已取消
channel.basicAck(msg.getMessageProperties().getDeliveryTag(),//應(yīng)答的消息
false//是否批量應(yīng)答
);
}
}七、在業(yè)務(wù)代碼中注入發(fā)送類,并調(diào)用發(fā)送類的發(fā)送方法
@Service
public class OrderServiceImpl implements OrderService {
@Autowired
private SendRabbitMQ sendRabbitMQ;
/**
* 用戶下單
*/
public void submitOrder(OrdersSubmitDTO ordersSubmitDTO) {
sendRabbitMQ.sendDelayOrder(order.getId());//發(fā)送延遲消息到消息隊(duì)列
}
}到此這篇關(guān)于使用RabbitMQ實(shí)現(xiàn)延時(shí)消息自動(dòng)取消的簡(jiǎn)單案例的文章就介紹到這了,更多相關(guān)RabbitMQ延時(shí)消息自動(dòng)取消內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Spring Boot快速實(shí)現(xiàn) IP地址解析的示例詳解
這篇文章主要介紹了Spring Boot快速實(shí)現(xiàn)IP地址解析,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-08-08
Java中JFrame實(shí)現(xiàn)無(wú)邊框無(wú)標(biāo)題方法
這篇文章主要介紹了Java中JFrame實(shí)現(xiàn)無(wú)邊框無(wú)標(biāo)題方法,本文直接給出代碼實(shí)例,需要的朋友可以參考下2015-05-05
Java超詳細(xì)分析繼承與重寫(xiě)的特點(diǎn)
繼承是Java面向?qū)ο缶幊讨械囊婚T。繼承是子類繼承父類的特征和行為,或者是繼承父類得方法,使的子類具有父類得的特性和行為。重寫(xiě)是子類對(duì)父類的允許訪問(wèn)的方法實(shí)行的過(guò)程進(jìn)行重新編寫(xiě),返回值和形參都不能改變。就是對(duì)原本的父類進(jìn)行重新編寫(xiě),但是外部接口不能被重寫(xiě)2022-05-05
SpringCloud通過(guò)Feign傳遞List類型參數(shù)方式
這篇文章主要介紹了SpringCloud通過(guò)Feign傳遞List類型參數(shù)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03
淺析JAVA常用JDBC連接數(shù)據(jù)庫(kù)的方法總結(jié)
本篇文章是對(duì)在JAVA中常用JDBC連接數(shù)據(jù)庫(kù)的方法進(jìn)行了詳細(xì)的總結(jié)分析,需要的朋友參考下2013-07-07
IDEA導(dǎo)入JDBC驅(qū)動(dòng)的jar包步驟詳解
JDBC是一種底層的API,是連接數(shù)據(jù)庫(kù)和Java應(yīng)用程序的紐帶,因此我們?cè)谠L問(wèn)數(shù)據(jù)庫(kù)時(shí)需要在業(yè)務(wù)邏輯層中嵌入SQL語(yǔ)句,這篇文章主要介紹了IDEA導(dǎo)入JDBC驅(qū)動(dòng)的jar包,需要的朋友可以參考下2023-07-07

