首页 > 其他 > 详细

如何实现分布式的延时队列

时间:2021-04-14 23:30:27      阅读:24      评论:0      收藏:0      [点我收藏+]

借助redisson实现延时队列

public class RedissonDelayQueue {

    private RedissonClient redissonClient;
    private RBlockingDeque<String> rBlockingDeque;
    private RDelayedQueue<String> rDelayedQueue;

    public void delaySend(String jsonObject, Long delay, TimeUnit timeUnit) {
        this.rDelayedQueue.offer(jsonObject, delay, timeUnit);
    }

    public RedissonDelayQueue() {
        Config config = new Config();
        config.useClusterServers().setScanInterval(2000).addNodeAddress("redis://10.13.65.178:6390");
        this.redissonClient = Redisson.create(config);
        this.rBlockingDeque = redissonClient.getBlockingDeque("MXZ_DELAY_QUEUE");
        if (this.rBlockingDeque == null) {
            return;
        }
        this.rDelayedQueue = redissonClient.getDelayedQueue(rBlockingDeque);
        if (this.rDelayedQueue == null) {
            return;
        }
        this.startConsumerDelayQueue();
        System.out.println("启动时间" + LocalDateTime.now());
    }

    private void startConsumerDelayQueue() {

        Thread thread = new Thread(() -> {
            while (true) {
                try {
                    String jsonObject = this.rBlockingDeque.take();
                    System.out.println("--> 延迟队列获取数据:{}" + jsonObject);
                } catch (InterruptedException e) {

                }
            }
        });
        thread.setDaemon(true);
        thread.start();
    }

    public static void main(String[] args) {

        RedissonDelayQueue queue = new RedissonDelayQueue();
        queue.delaySend("one", 10l,TimeUnit.SECONDS);

        queue.delaySend("two", 20l,TimeUnit.SECONDS);
    }
}

 

如何实现分布式的延时队列

原文:https://www.cnblogs.com/juniorMa/p/14659856.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!