Spring Cloud Stream RabbitMQ普通实现+延时消息+死信队列

配置和代码示例

参考文档
Spring Cloud Stream RabbitMQ Binder Reference Guide
依赖

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-stream-rabbit</artifactId>
</dependency>

配置

spring:
	cloud:
	    stream:
	      #RabbitMQ服务器地址配置
	      binders:
	        windrabbit:
	          type: rabbit
	          environment:
	            spring:
	              rabbitmq:
	                addresses: localhost
	                port: 15672
	                username: guest
	                password: guest
	      bindings:
	        order-output:
	          destination: order.exchange
	          binder: windrabbit
	          content-type: application/json
	          group: order
	        order-input:
	          destination: order.exchange
	          binder: windrabbit
	          content-type: application/json
	          group: order
	        delay-output:
	          destination: delay.exchange
	          binder: windrabbit
	          content-type: application/json
	          group: delay-order
	          producer:
	            requiredGroups: delay-order
	        delay-input:
	          destination: delay.exchange
	          binder: windrabbit
	          content-type: application/json
	          group: delay-order
	      #这一部分是给上边声明的bindings添加配置的,例如队列的ttl,还有要不要给队列配置死信队列
	      rabbit:
	        bindings:
	          delay-output:
	            producer:
	              ttl: 120000#队列里的消息如果120000ms之后还没被消费,就会成为死信,这个参数生效的前提是spring.cloud.stream.bindings里边声明了requiredGroups
	              autoBindDlq: true#这个参数为true的时候会自动为当前的队列创建一个死信队列,以dlq结尾

新建一个Processor来映射上边配置的bindings

import org.springframework.cloud.stream.annotation.Input;
import org.springframework.cloud.stream.annotation.Output;
import org.springframework.messaging.MessageChannel;
import org.springframework.messaging.SubscribableChannel;
import org.springframework.stereotype.Component;

@Component
public interface MQOrderProcessor {
    String INPUT="order-input";
    @Input(MQOrderProcessor.INPUT)
    SubscribableChannel orderInput();
//    String DELAYINPUT="delay-input";
//    @Input(MQOrderProcessor.DELAYINPUT)
//    SubscribableChannel delayOrderInput();
    String OUTPUT="order-output";
    @Output(MQOrderProcessor.OUTPUT)
    MessageChannel orderOutput();
    String DELAYOUTPUT="delay-output";
    @Output(MQOrderProcessor.DELAYOUTPUT)
    MessageChannel delayOrderOutput();
}

发送消息的代码

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.cloud.stream.annotation.EnableBinding;
import com.wind.valley.mq.processor.MQOrderProcessor;
import org.springframework.messaging.support.MessageBuilder;

@EnableBinding(MQOrderProcessor.class)
public class OrderMessageProvider  {
    @Autowired
    private MQOrderProcessor processor;
    public boolean sendCancelOrderMessage(){
        System.out.println("start send message to mq");
        return processor.delayOrderOutput().send(MessageBuilder.withPayload("{message:'cancel order'}").build());
    }
}

监听消息的代码

import com.alibaba.fastjson.JSON;
import com.wind.valley.mq.processor.MQOrderProcessor;
import org.springframework.cloud.stream.annotation.EnableBinding;
import org.springframework.cloud.stream.annotation.StreamListener;

@EnableBinding(MQOrderProcessor.class)
public class OrderMessageConsumer {
    @StreamListener(MQOrderProcessor.INPUT)
    public void process(Object obj) {
        System.out.println("get message"+JSON.toJSONString(obj));
    }
//    @StreamListener(MQOrderProcessor.DELAYINPUT)
//    public void delayProcess(Object obj) {
//        System.out.println("get delay message"+JSON.toJSONString(obj));
//    }
}

普通队列的实现步骤

生产者

  1. 引入依赖
  2. 配置rabbitmq服务端spring.cloud.stream.binders
  3. 配置bindings spring.cloud.stream.bindings.xx-output
  4. 为bindings配置Processor(接口)
public interface MQOrderProcessor {
//对应bindings的名称
	String OUTPUT="order-output";
	@Output(MQOrderProcessor.OUTPUT)
    MessageChannel orderOutput();
}
  1. 发送消息的示例代码
@EnableBinding(MQOrderProcessor.class)
public class OrderMessageProvider  {
    @Autowired
    private MQOrderProcessor processor;
    public boolean sendCancelOrderMessage(){
        System.out.println("start send message to mq");
        return processor.delayOrderOutput().send(MessageBuilder.withPayload("{message:'cancel order'}").build());
    }
}

消费者

  1. 引入依赖
  2. 配置rabbitmq服务端spring.cloud.stream.binders
  3. 配置bindings spring.cloud.stream.bindings.xx-input(destination指向生产者destination)
  4. 为bindings配置Processor(接口)
public interface MQOrderProcessor {
    String INPUT="order-input";
    @Input(MQOrderProcessor.INPUT)
    SubscribableChannel orderInput();
}
  1. 监听Processor的input,这一步是添加具体实现,如果不做这一步,消息就会被Processor消费掉
@EnableBinding(MQOrderProcessor.class)
public class OrderMessageConsumer {
    @StreamListener(MQOrderProcessor.INPUT)
    public void process(Object obj) {
        System.out.println("get message"+JSON.toJSONString(obj));
    }
//    @StreamListener(MQOrderProcessor.DELAYINPUT)
//    public void delayProcess(Object obj) {
//        System.out.println("get delay message"+JSON.toJSONString(obj));
//    }
}

延迟队列与死信队列实现30分钟未支付,取消订单

  1. 在普通队列的基础上,配置延迟队列的关键属性spring.cloud.stream.rabbit.bindings.xx-output.producer.ttl,spring.cloud.stream.bindings.xx-output.producer.requiredGroups
  2. 为延迟队列添加属性spring.cloud.stream.rabbit.bindings.xx-output.producer.autoBindDlq=true,就会自动创建一个死信队列,延迟队列里的超时未消费的消息就会移动到这个死信队列里,自动添加的死信队列的名称为延迟队咧的destination+.dlq
  3. 写一个消费者消费死信队列里的消息就好了
    在这里插入图片描述
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
【2021年,将Spring全家桶系列课程进行Review,修复顺序等错误。进入2022年,将Spring的课程进行整理,整理为案例精讲的系列课程,并新增高级的Spring Security等内容,通过手把手一步步教你从零开始学会应用Spring,课件将逐步进行上传,敬请期待】 本课程是Spring案例精讲课程的第四部分Spring CloudSpring案例精讲课程以真实场景、项目实战为导向,循序渐进,深入浅出的讲解Java网络编程,助力您在技术工作中更进一步。 本课程聚焦Spring Cloud的核心知识点:注册中心、服务提供者与消费者、服务的调用OpenFeign、Hystrix监控、服务网关gateway、消息驱动的微服务Spring Cloud Stream、分布式集群、分布式配置中心的案例介绍, 快速掌握Spring Cloud的核心知识,快速上手,为学习及工作做好充足的准备。 由于本课程聚焦于案例,即直接上手操作,对于Spring的原理等不会做过多介绍,希望了解原理等内容的需要通过其他视频或者书籍去了解,建议按照该案例课程一步步做下来,之后再去进一步回顾原理,这样能够促进大家对原理有更好的理解。【通过Spring全家桶,我们保证你能收获到以下几点】 1、掌握Spring全家桶主要部分的开发、实现2、可以使用Spring MVC、Spring Boot、Spring CloudSpring Data进行大部分的Spring开发3、初步了解使用微服务、了解使用Spring进行微服务的设计实现4、奠定扎实的Spring技术,具备了一定的独立开发的能力  【实力讲师】 毕业于清华大学软件学院软件工程专业,曾在Accenture、IBM等知名外企任管理及架构职位,近15年的JavaEE经验,近8年的Spring经验,一直致力于架构、设计、开发及管理工作,在电商、零售、制造业等有丰富的项目实施经验  【本课程适用人群】如果你是一定不要错过!  适合于有JavaEE基础的,如:JSP、JSTL、Java基础等的学习者没有基础的学习者跟着课程可以学习,但是需要补充相关基础知识后,才能很好的参与到相关的工作中。 【Spring全家桶课程共包含如下几门】 

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值