SpringCoud Stream 实现延时消息队列

快速根据代码进行上手,后面补充原理。。。。

配置文件

spring.rabbitmq.host=******
spring.rabbitmq.port=5672
spring.rabbitmq.username=guest
spring.rabbitmq.password=guest
spring.rabbitmq.virtual-host=/

#消费者开启延时队列支持
spring.cloud.stream.rabbit.bindings.input-channe.consumer.delayed-exchange=true
#生产者开启延时队列支持
spring.cloud.stream.rabbit.bindings.onput-channe.producer.delayed-exchange=true
#指定消息所属exchange
spring.cloud.stream.bindings.input_channel.destination=my-exchange
#指定消费者分组,在多实例的时候必需指定,防止重复消费
spring.cloud.stream.bindings.input_channel.group=my-mq
#指定消息所属exchange
spring.cloud.stream.bindings.output_channel.destination=my-exchange
spring.cloud.stream.bindings.output_channel.group=my-mq

创建Sink

public interface MySink {

    String input_channel = "input_channel";

    @Input(input_channel)
    SubscribableChannel in();
}

创建Source

public interface MySource {
    String output_channel = "output_channel";

    /**
     * @return output channel
     */
    @Output(output_channel)
    MessageChannel out();
}

创建消费者

@Component
@EnableBinding(MySink.class)
@Log4j2
public class MyConsumer {

    @StreamListener(MySink.input_channel)
    public void input(Message<Map<String,Object>> message){
        log.info("收到消息:{}", message.getPayload());

    }


}

创建生产者

@EnableBinding(MySource.class)
@Component
@Log4j2
public class MySender {
    @Autowired
    private MySource source;


    public String sendDelayedMessage(String body,
                                      Integer seconds) {

        Map<String,Object> message = new HashMap<>();
        message.put("body", body);
        source.out().send(
                MessageBuilder.withPayload(message)
                        .setHeader("x-delay", seconds * 1000)
                        .build()
        );
        log.info("发送延迟消息成功");
        return "SUCCESS";
    }

}

启动服务后RabbitMq页面显示交换机情况

在这里插入图片描述

队列情况

在这里插入图片描述

调用

@RestController
@RequestMapping("/delayed")
@Log4j2
public class DelayedCtrl {

    @Autowired
    private MySender sender;


    @GetMapping("/delayed")
    public String sendDelayedMessage(@RequestParam("body") String body,
                                     @RequestParam("seconds") Integer seconds) {

        sender.sendDelayedMessage(body,seconds);
        return "SUCCESS";
    }
}

效果

在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Redis Stream 可以用作消息队列,其实现方式如下: 1. 创建一个 Stream,用于存储消息。可以使用 XADD 命令向 Stream 中添加消息,消息的格式为 key-value 形式,其中 key 表示消息 ID,value 表示消息内容。 ```redis XADD mystream * message "hello" ``` 2. 消费消息。可以使用 XREAD 命令从 Stream 中读取消息,可以指定读取的消息数量和读取的位置。如果 Stream 中没有消息,则可以使用 XREADBLOCK 命令进行阻塞读取,直到有消息到达为止。 ```redis XREAD COUNT 10 STREAMS mystream 0 ``` 3. 确认消息已经被消费。可以使用 XACK 命令确认消息已经被消费,避免消息被重复消费。 ```redis XACK mystream group1 message-id ``` 4. 使用消费者组。如果有多个消费者消费同一个 Stream,可以使用消费者组进行管理。可以使用 XGROUP CREATE 命令创建一个消费者组,使用 XREADGROUP 命令从组中读取消息,并使用 XACK 命令确认消息已经被消费。 ```redis XGROUP CREATE mystream group1 0 XREADGROUP GROUP group1 consumer1 COUNT 10 STREAMS mystream > XACK mystream group1 message-id ``` 使用 Redis Stream 实现消息队列的优点包括: 1. Redis Stream 可以支持高性能的消息队列,多个消费者可以并发消费消息,提高了消息处理的效率。 2. Redis Stream 支持消息确认和消费者组,可以保证消息不会重复消费,同时可以进行消费者的管理和协作。 3. Redis Stream 内部使用日志数据结构,支持高可靠性和高可扩展性。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值