qirong
2023-12-08 fb766b5ff9f913561f76aa747c76eae5c3678589
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
//package org.dromara.demo.controller.queue;
//
//import cn.dev33.satoken.annotation.SaIgnore;
//import org.dromara.common.core.domain.R;
//import org.dromara.common.redis.utils.QueueUtils;
//import lombok.RequiredArgsConstructor;
//import lombok.extern.slf4j.Slf4j;
//import org.springframework.web.bind.annotation.GetMapping;
//import org.springframework.web.bind.annotation.RequestMapping;
//import org.springframework.web.bind.annotation.RequestParam;
//import org.springframework.web.bind.annotation.RestController;
//
//import java.util.concurrent.TimeUnit;
//
///**
// * 延迟队列 演示案例
// * <p>
// * 轻量级队列 重量级数据量 请使用 MQ
// * 例如: 创建订单30分钟后过期处理
// * <p>
// * 集群测试通过 同一个数据只会被消费一次 做好事务补偿
// * 集群测试流程 两台集群分别开启订阅 在其中一台发送数据 观察接收消息的规律
// *
// * @author Lion Li
// * @version 3.6.0
// */
//@SaIgnore
//@Slf4j
//@RequiredArgsConstructor
//@RestController
//@RequestMapping("/demo/queue/delayed")
//public class DelayedQueueController {
//
//    /**
//     * 订阅队列
//     *
//     * @param queueName 队列名
//     */
//    @GetMapping("/subscribe")
//    public R<Void> subscribe(String queueName) {
//        log.info("通道: {} 监听中......", queueName);
//        // 项目初始化设置一次即可
//        QueueUtils.subscribeBlockingQueue(queueName, (String orderNum) -> {
//            // 观察接收时间
//            log.info("通道: {}, 收到数据: {}", queueName, orderNum);
//
//        });
//        return R.ok("操作成功");
//    }
//
//    /**
//     * 添加队列数据
//     *
//     * @param queueName 队列名
//     * @param orderNum  订单号
////     * @param time      延迟时间(秒)
//     */
//    @GetMapping("/add")
//    public R<Void> add(@RequestParam("queueName") String queueName, @RequestParam("orderNum")String orderNum) {
//        QueueUtils.addDelayedQueueObject(queueName, orderNum, 5, TimeUnit.SECONDS);
//        // 观察发送时间
//        log.info("通道: {} , 发送数据: {}", queueName, orderNum);
//        return R.ok("操作成功");
//    }
//
//    /**
//     * 删除队列数据
//     *
//     * @param queueName 队列名
//     * @param orderNum  订单号
//     */
//    @GetMapping("/remove")
//    public R<Void> remove(String queueName, String orderNum) {
//        if (QueueUtils.removeDelayedQueueObject(queueName, orderNum)) {
//            log.info("通道: {} , 删除数据: {}", queueName, orderNum);
//        } else {
//            return R.fail("操作失败");
//        }
//        return R.ok("操作成功");
//    }
//
//    /**
//     * 销毁队列
//     *
//     * @param queueName 队列名
//     */
//    @GetMapping("/destroy")
//    public R<Void> destroy(String queueName) {
//        // 用完了一定要销毁 否则会一直存在
//        QueueUtils.destroyDelayedQueue(queueName);
//        return R.ok("操作成功");
//    }
//
//}