| | |
| | | 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("操作成功"); |
| | | } |
| | | |
| | | } |
| | | //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("操作成功"); |
| | | // } |
| | | // |
| | | //} |