From f44e4d609e7efaed9eac545137970b1e334f8106 Mon Sep 17 00:00:00 2001 From: mitao <2763622819@qq.com> Date: 星期六, 21 九月 2024 09:01:36 +0800 Subject: [PATCH] 修改bug --- ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/async/AsyncMethodService.java | 81 +++++++++++++++++++++------------------- 1 files changed, 42 insertions(+), 39 deletions(-) diff --git a/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/async/AsyncMethodService.java b/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/async/AsyncMethodService.java index fe612a3..f1b1ae1 100644 --- a/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/async/AsyncMethodService.java +++ b/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/async/AsyncMethodService.java @@ -3,13 +3,14 @@ import com.ruoyi.common.core.constant.SecurityConstants; import com.ruoyi.common.core.utils.StringUtils; import com.ruoyi.common.redis.service.RedisService; -import com.ruoyi.goods.domain.GoodsGroupPurchase; import com.ruoyi.system.api.constants.DelayTaskEnum; import com.ruoyi.system.api.domain.DelayTask; +import com.ruoyi.system.api.domain.GoodsGroupPurchase; import com.ruoyi.system.api.domain.GoodsSeckill; import com.ruoyi.system.api.feignClient.SysUserClient; import java.time.Duration; import java.time.LocalDateTime; +import java.util.List; import java.util.concurrent.TimeUnit; import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; @@ -31,50 +32,54 @@ @Async @Transactional(rollbackFor = Exception.class) - public void seckillScheduleTask(GoodsSeckill goodsSeckill) { - LocalDateTime startTime = goodsSeckill.getStartTime(); - LocalDateTime endTime = goodsSeckill.getEndTime(); - //秒杀在一小时内开始 - if (isWithinOneHour(startTime)) { - Long id = goodsSeckill.getId(); - //秒杀已经开始 - if (LocalDateTime.now().isAfter(startTime)) { - handleStartDelayTask(id, DelayTaskEnum.SECKILL_START_TASK, startTime, 3L); - } else { - Duration duration = Duration.between(LocalDateTime.now(), startTime); - handleStartDelayTask(id, DelayTaskEnum.SECKILL_START_TASK, startTime, - duration.getSeconds()); + public void seckillScheduleTask(List<GoodsSeckill> goodsSeckillList) { + for (GoodsSeckill goodsSeckill : goodsSeckillList) { + LocalDateTime startTime = goodsSeckill.getStartTime(); + LocalDateTime endTime = goodsSeckill.getEndTime(); + // 秒杀在一小时内开始 + if (isWithinOneHour(startTime)) { + Long id = goodsSeckill.getId(); + // 秒杀已经开始 + if (LocalDateTime.now().isAfter(startTime)) { + handleStartDelayTask(id, DelayTaskEnum.SECKILL_START_TASK, startTime, 3L); + log.info(">>>>>>>>>>>>>>>>>>>>秒杀商品:{} 开始秒杀<<<<<<<<<<<<<<<<<<<<", id); + } else { + Duration duration = Duration.between(LocalDateTime.now(), startTime); + handleStartDelayTask(id, DelayTaskEnum.SECKILL_START_TASK, startTime, + duration.getSeconds()); + } + // 秒杀结束延时任务 + handleEndDelayTask(id, DelayTaskEnum.SECKILL_END_TASK, endTime); } - log.info(">>>>>>>>>>>>>>>>>>>>秒杀商品:{} 开始秒杀<<<<<<<<<<<<<<<<<<<<", id); - //秒杀结束延时任务 - handleEndDelayTask(id, DelayTaskEnum.SECKILL_END_TASK, endTime); - } } @Async @Transactional(rollbackFor = Exception.class) - public void groupPurchaseScheduleTask(GoodsGroupPurchase groupPurchase) { - LocalDateTime startTime = groupPurchase.getStartTime(); - LocalDateTime endTime = groupPurchase.getEndTime(); - //秒杀在一小时内开始 - if (isWithinOneHour(startTime)) { - Long id = groupPurchase.getId(); - //秒杀已经开始,三秒后执行 - if (LocalDateTime.now().isAfter(startTime)) { - handleStartDelayTask(id, DelayTaskEnum.GROUP_PURCHASES_START_TASK, startTime, 3L); - } else { - Duration duration = Duration.between(LocalDateTime.now(), startTime); - handleStartDelayTask(id, DelayTaskEnum.GROUP_PURCHASES_START_TASK, startTime, - duration.getSeconds()); + public void groupPurchaseScheduleTask(List<GoodsGroupPurchase> groupPurchaseList) { + for (GoodsGroupPurchase goodsGroupPurchase : groupPurchaseList) { + LocalDateTime startTime = goodsGroupPurchase.getStartTime(); + LocalDateTime endTime = goodsGroupPurchase.getEndTime(); + // 团购在一小时内开始 + if (isWithinOneHour(startTime)) { + Long id = goodsGroupPurchase.getId(); + // 团购已经开始,三秒后执行 + if (LocalDateTime.now().isAfter(startTime)) { + handleStartDelayTask(id, DelayTaskEnum.GROUP_PURCHASES_START_TASK, startTime, + 3L); + } else { + Duration duration = Duration.between(LocalDateTime.now(), startTime); + handleStartDelayTask(id, DelayTaskEnum.GROUP_PURCHASES_START_TASK, startTime, + duration.getSeconds()); + } + // 团购结束延时任务 + handleEndDelayTask(id, DelayTaskEnum.GROUP_PURCHASES_END_TASK, endTime); } - //秒杀结束延时任务 - handleEndDelayTask(id, DelayTaskEnum.GROUP_PURCHASES_END_TASK, endTime); } } - + private boolean isWithinOneHour(LocalDateTime startTime) { - LocalDateTime checkTime = LocalDateTime.now().plusHours(1); + LocalDateTime checkTime = LocalDateTime.now().plusMinutes(61); return checkTime.isAfter(startTime); } @@ -114,9 +119,6 @@ private void handleStartDelayTask(Long id, DelayTaskEnum delayTaskEnum, LocalDateTime startTime, Long timeout) { String startTaskKey = delayTaskEnum.getCode() + "-" + id; - redisService.setCacheObject( - startTaskKey, - startTime, timeout, TimeUnit.SECONDS); //查询延时任务 DelayTask startDelayTask = sysUserClient.getDelayTask( startTaskKey, SecurityConstants.INNER).getData(); @@ -139,9 +141,10 @@ startDelayTask.setExecuteTime(LocalDateTime.now().plusSeconds(timeout)); startDelayTask.setRedisKey( startTaskKey); - sysUserClient.addDelayTask(startDelayTask, SecurityConstants.INNER); + } } + redisService.setCacheObject(startTaskKey, startTime, timeout, TimeUnit.SECONDS); log.info(">>>>>>>>>>>>>>>>>>>>延时任务{}执行了<<<<<<<<<<<<<<<<<<<<", startTaskKey); } } -- Gitblit v1.7.1