当前位置:   article > 正文

Redssion通过RDelayedQueue实现延迟任务

rdelayedqueue

问题背景

我们在日常开发中经常会遇到例如延时关闭订单这类任务,今天我么遇到的问题和延迟订单类似,就是在一条信息发布后,在规定的时间内没有人回复,则需要将该条留言关闭隐藏!其实,和订单关闭问题是一致的!

接下来我们就会通过Redission的RDelayedQueue(延迟队列)来实现我们的消息关闭!

使用步骤

使用过程其实很简单:

  1. 将消息放到RDelayedQueue(延迟队列)中;
  2. 从RDelayedQueue(延迟队列)中取出消息进行消费

具体实现

  1. 我这里使用的是Springboot的maven项目,打开pom文件,添加相关依赖
  1. <dependency>
  2. <groupId>org.redisson</groupId>
  3. <artifactId>redisson</artifactId>
  4. <version>3.12.0</version>
  5. </dependency>
  1. 配置类RedissonConfig 通过配置类RedissonConfig来配置我们的Bean——RedissonClient, 连接Redis地址、端口、密码等。

    需要注意的是这里面如果密码为null的时候不需要显示的配置,具体代码如下所示:

  1. @Configuration
  2. public class RedissonConfig {
  3. @Value("${spring.redis.host}")
  4. private String host;
  5. @Value("${spring.redis.port}")
  6. private int port;
  7. @Value("${spring.redis.database}")
  8. private int database;
  9. @Value("${spring.redis.password}")
  10. private String password;
  11. @Bean
  12. public RedissonClient redissonClient() {
  13. Config config = new Config();
  14. SingleServerConfig singleServerConfig = config.useSingleServer()
  15. .setAddress("redis://" + host + ":" + port)
  16. .setDatabase(database);
  17. if (!StringUtils.isEmpty(password)) {
  18. singleServerConfig.setPassword(password);
  19. }
  20. return Redisson.create(config);
  21. }
  22. }
  1. 我们的定时任务工具类RedisDelayQueueUtil

    核心代码如下:

  1. RBlockingDeque<Object> blockingDeque = redissonClient.getBlockingDeque(queueCode);
  2. RDelayedQueue<Object> delayedQueue = redissonClient.getDelayedQueue(blockingDeque);
  3. delayedQueue.offer(value, delay, timeUnit);

获取到了队列标记后,完成队列定义,最后将value按照delay定义的时长,timeUnit作为时长单位标识发送出去。

这样一个最基本的延迟任务就完成了!

4.获取延迟任务消息

具体核心代码如下:

  1. RBlockingDeque<Map> blockingDeque = redissonClient.getBlockingDeque(queueCode);
  2. T value = (T) blockingDeque.take();

代码中拿到queueCode队列后,获取到消息主体Value,然后我们在完成自己的业务逻辑即可

到这,我们的延迟任务核心功能就完成了,欢迎大家留言交流,也欢迎大家关注我的公号《coder练习生》

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号