RabbitMQ之延迟消息实战

RabbitMQ之延迟消息实战

  1. 使用死信交换机实现延迟消息

    使用死信交换机的过期时间以及没有消费者进行消费,时间到了就会到死信队列中,由此可以实现延迟消息
  2. 使用延迟消息插件
    前提:需要mq配置插件

  3. 延时信息案例实战
    把一个30分钟的延迟消息可以拆分成各个小时间段来优化MQ大量信息的压力


    代码实现
    (1)定义消息体对象
java 复制代码
@Data
public class MultyDelayMessage<T>{
	// 消息体
	private T data;
	// 记录延迟时间的集合
	private List<Long> delayMillis;
	
	public MultiDelayMessage(T data List<Long> delayMilis){
		this.data = data;
		this.delayMillis = delayMillis;
	}
	public static <T> MultiDelayMessage<T> of(T data,Long ... delayMillis){
		return new MultiDelayMessage<>(data,Collutils.newArrayList(delayMilis));
	}
	//获取并移除下一个延迟时间,返回队列中的第一个延时时间
	public Long removeNextDelay{
		return delayMillis.remove(0);
	}
	// 判断是否有下一个延时时间
	public bollean hasNextDelay(){
		return !delayMilis.isEmpty();
	}
}

(2)定义队列名称

java 复制代码
public interface MqConstants{
	String DELAY_EXCHANGE = "trade.delay.topic";
	String DELAY_ORDER_QUEUE = "trade.order.delay.queue";
	String DELAY_ORDER_ROUTING_KEY = "order.query"-;
}

(3)创建订单发送延迟消息

java 复制代码
MultiDelayMessage<Long> msg = MultiDelayMessage.of(order.getId(),10000L,10000L,10000L,15000L,15000L,30000L,30000L);
rabbitTemplate.convertAndSend(MqConstants,DELAY_EXCHANGE,DELAY_ORDER_ROUTING_KEY,msg,new MessagePostProcess{
	@Override
	public Message postProcessMessage(Message message) throw AmqpException{
		message.getMessageProperties().setDelay(msg.removeNextDelay().intValue());
	}
});

(4)监听到延迟消息处理订单状态

java 复制代码
@Component
public class OrderStatusChechListenter{
	
	@Autowrid
	private OrderService orderService;

	@RabbitListener(@QueueBinding(value=@Queue(value=MqConstants.DELAY_ORDER_QUEUE,durable="true"),exchange=@Exchange(value=MqConstants.DELAY_EXCHANGE,delayed="true",type=ExchangeTypes.TOPIC),key=MqConstants.DELAY_ORDER_ROUTING_KEY))
public void listenOrderDelayMessage(MultiDelayMessage message){
	// 查询订单支持状态
	Order order = orderService.getById(message.getData());
	if(order == null || order.getStatus == 2){// 已支付
		return;
	}
	// 查询支付服务该订单的支付状态
	boolean isPay = payServive.getById(order.getBussesesId());
	if(isPay){
		// 已支付
		orderService.markOrderPaySuccess(order.getId());
		return;
	}
	// 未支付,并且有延迟时间
	if(msg.hasNextDelay()){
		//重发延迟消息
		Long nextDelay = msg.removeNextDelay();
		rabbitTemplate.convertAndSend(MqConstants,DELAY_EXCHANGE,DELAY_ORDER_ROUTING_KEY,msg,new MessagePostProcess{
	@Override
	public Message postProcessMessage(Message message) throw AmqpException{
		message.getMessageProperties().setDelay(nextDelay.intValue());	}
});
	return;
	}
	// 没有延迟消息,取消订单
	orderService.cancleOrder(order.getId());
	//恢复库存
	orderService.updateStore(order.getId());
}

}
相关推荐
h7ml1 天前
基于 RabbitMQ 构建异步化淘客订单处理流水线:解耦、削峰与失败重试
分布式·rabbitmq·ruby
小北方城市网2 天前
Spring Boot Actuator+Prometheus+Grafana 生产级监控体系搭建
java·spring boot·python·rabbitmq·java-rabbitmq·grafana·prometheus
不想写bug呀2 天前
RabbitMQ集群和仲裁队列
rabbitmq·集群·仲裁队列
信创天地3 天前
国产化数据库深度运维:性能调优与故障排查实战指南
运维·数据库·安全·elk·自动化·rabbitmq
jiayong233 天前
MQ基础概念面试题
java·kafka·rabbitmq·rocketmq
成为你的宁宁3 天前
【RabbitMQ 集群企业级实战:RabbitMQ 特性、存储、工作模式解析与普通集群搭建及仲裁队列搭建企业级配置】
分布式·rabbitmq
Anastasiozzzz3 天前
RabbitMQ介绍与基础架构
分布式·rabbitmq
洛阳纸贵3 天前
JAVA高级工程师--RabbitMQ消息可靠性、若依集成升级
java·rabbitmq·java-rabbitmq
jiayong233 天前
MQ性能优化面试题
java·性能优化·kafka·rabbitmq
小北方城市网4 天前
Spring Cloud Gateway 全链路监控与故障自愈实战
spring boot·python·rabbitmq·java-rabbitmq·数据库架构