| | |
| | | import javax.annotation.Resource; |
| | | import java.time.LocalDateTime; |
| | | import java.time.ZoneId; |
| | | import java.time.ZoneOffset; |
| | | import java.util.List; |
| | | import java.util.Set; |
| | | |
| | | /** |
| | | * <p> |
| | |
| | | if (subscribe.getOrderId() != null){ |
| | | orderGoodsClient.subscribe(subscribe.getOrderId(), subscribe.getTechnicianId()); |
| | | } |
| | | LocalDateTime subscribeTime = subscribe.getSubscribeTime(); |
| | | long deadlineTimestamp = subscribeTime.atZone(ZoneId.systemDefault()).toEpochSecond(); |
| | | redisTemplate.opsForZSet().add("delay_queue:subscribe", subscribe.getId().toString(), deadlineTimestamp); |
| | | //添加到redis有序队列中用于定时处理状态 |
| | | redisTemplate.opsForZSet().add("technician_subscribe", subscribe.getId().toString(), subscribe.getSubscribeTime().toEpochSecond(ZoneOffset.UTC)); |
| | | } |
| | | |
| | | |
| | |
| | | */ |
| | | @Override |
| | | public void taskEditStstus() { |
| | | List<TechnicianSubscribe> list = this.list(new LambdaQueryWrapper<TechnicianSubscribe>().eq(TechnicianSubscribe::getStatus, 0).eq(TechnicianSubscribe::getDelFlag, 0) |
| | | .lt(TechnicianSubscribe::getSubscribeTime, LocalDateTime.now())); |
| | | list.forEach(s->s.setStatus(3)); |
| | | if(list.size() > 0){ |
| | | Set<String> technician_subscribe = redisTemplate.opsForZSet().range("technician_subscribe", 0, LocalDateTime.now().toEpochSecond(ZoneOffset.UTC)); |
| | | if(technician_subscribe.size() > 0){ |
| | | List<TechnicianSubscribe> list = this.listByIds(technician_subscribe); |
| | | list.forEach(s->s.setStatus(3)); |
| | | this.updateBatchById(list); |
| | | redisTemplate.opsForZSet().remove("technician_subscribe", technician_subscribe.toArray()); |
| | | } |
| | | } |
| | | } |