| | |
| | | package com.ruoyi.goods.service.async; |
| | | |
| | | 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 lombok.RequiredArgsConstructor; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | import org.springframework.scheduling.annotation.Async; |
| | | import org.springframework.stereotype.Component; |
| | | import org.springframework.stereotype.Service; |
| | | import org.springframework.transaction.annotation.Transactional; |
| | | |
| | | /** |
| | | * @author mitao |
| | | * @date 2024/5/24 |
| | | */ |
| | | @Component |
| | | @Service |
| | | @Slf4j |
| | | @RequiredArgsConstructor |
| | | public class AsyncMethodService { |
| | |
| | | private final SysUserClient sysUserClient; |
| | | |
| | | @Async |
| | | @Transactional(rollbackFor = Exception.class) |
| | | public void seckillScheduleTask(GoodsSeckill goodsSeckill) { |
| | | LocalDateTime startTime = goodsSeckill.getStartTime(); |
| | | LocalDateTime endTime = goodsSeckill.getEndTime(); |
| | |
| | | } |
| | | |
| | | @Async |
| | | @Transactional(rollbackFor = Exception.class) |
| | | public void groupPurchaseScheduleTask(GoodsGroupPurchase groupPurchase) { |
| | | LocalDateTime startTime = groupPurchase.getStartTime(); |
| | | LocalDateTime endTime = groupPurchase.getEndTime(); |
| | |
| | | private void handleEndDelayTask(Long id, DelayTaskEnum delayTaskEnum, LocalDateTime endTime) { |
| | | String endTaskKey = delayTaskEnum.getCode() + "-" + id; |
| | | DelayTask endDelayTask = sysUserClient.getDelayTask( |
| | | endTaskKey).getData(); |
| | | endTaskKey, SecurityConstants.INNER).getData(); |
| | | // 如果延时任务为空,创建延时任务控制活动定时开始和结束 |
| | | Duration duration = Duration.between(LocalDateTime.now(), endTime); |
| | | if (StringUtils.isNull(endDelayTask)) { |
| | | createEndDelayTask(endTime, endTaskKey, duration); |
| | | } else { |
| | | if (!endDelayTask.getExecuteTime().isEqual(endTime)) { |
| | | sysUserClient.deleteDelayTask(endTaskKey); |
| | | sysUserClient.deleteDelayTask(endTaskKey, |
| | | SecurityConstants.INNER); |
| | | redisService.deleteObject(endTaskKey); |
| | | createEndDelayTask(endTime, endTaskKey, duration); |
| | | } |
| | |
| | | endDelayTask.setCreateTime(LocalDateTime.now()); |
| | | endDelayTask.setExecuteTime(endTime); |
| | | endDelayTask.setRedisKey(seckillEndTaskKey); |
| | | sysUserClient.addDelayTask(endDelayTask); |
| | | sysUserClient.addDelayTask(endDelayTask, SecurityConstants.INNER); |
| | | } |
| | | |
| | | private void handleStartDelayTask(Long id, DelayTaskEnum delayTaskEnum, LocalDateTime startTime, |
| | | Long timeout) { |
| | | String startTaskKey = delayTaskEnum.getCode() + "-" + id; |
| | | //查询延时任务 |
| | | DelayTask startDelayTask = sysUserClient.getDelayTask( |
| | | startTaskKey).getData(); |
| | | redisService.setCacheObject( |
| | | startTaskKey, |
| | | startTime, timeout, TimeUnit.SECONDS); |
| | | //查询延时任务 |
| | | DelayTask startDelayTask = sysUserClient.getDelayTask( |
| | | startTaskKey, SecurityConstants.INNER).getData(); |
| | | if (StringUtils.isNull(startDelayTask)) { |
| | | startDelayTask = new DelayTask(); |
| | | startDelayTask.setDelFlag(0); |
| | |
| | | startDelayTask.setExecuteTime(LocalDateTime.now().plusSeconds(timeout)); |
| | | startDelayTask.setRedisKey( |
| | | startTaskKey); |
| | | sysUserClient.addDelayTask(startDelayTask); |
| | | sysUserClient.addDelayTask(startDelayTask, SecurityConstants.INNER); |
| | | } else { |
| | | if (!startDelayTask.getExecuteTime().isEqual(startTime)) { |
| | | sysUserClient.deleteDelayTask( |
| | | startTaskKey); |
| | | startTaskKey, SecurityConstants.INNER); |
| | | redisService.deleteObject( |
| | | startTaskKey); |
| | | startDelayTask.setDelFlag(0); |
| | |
| | | startDelayTask.setExecuteTime(LocalDateTime.now().plusSeconds(timeout)); |
| | | startDelayTask.setRedisKey( |
| | | startTaskKey); |
| | | sysUserClient.addDelayTask(startDelayTask); |
| | | sysUserClient.addDelayTask(startDelayTask, SecurityConstants.INNER); |
| | | } |
| | | } |
| | | log.info(">>>>>>>>>>>>>>>>>>>>延时任务{}执行了<<<<<<<<<<<<<<<<<<<<", startTaskKey); |