SceneCleanServiceImpl.java 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. package com.fdkankan.scene.service.impl;
  2. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  3. import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
  4. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  5. import com.fdkankan.common.constant.CommonStatus;
  6. import com.fdkankan.common.util.DateUtil;
  7. import com.fdkankan.model.constants.ConstantFilePath;
  8. import com.fdkankan.model.utils.CreateObjUtil;
  9. import com.fdkankan.redis.constant.RedisKey;
  10. import com.fdkankan.redis.constant.RedisLockKey;
  11. import com.fdkankan.redis.util.RedisLockUtil;
  12. import com.fdkankan.scene.bean.SceneBean;
  13. import com.fdkankan.scene.entity.SceneClean;
  14. import com.fdkankan.scene.mapper.ISceneCleanMapper;
  15. import com.fdkankan.scene.service.ISceneCleanService;
  16. import lombok.extern.slf4j.Slf4j;
  17. import org.apache.commons.lang3.StringUtils;
  18. import org.springframework.beans.factory.annotation.Autowired;
  19. import org.springframework.beans.factory.annotation.Value;
  20. import org.springframework.cloud.context.config.annotation.RefreshScope;
  21. import org.springframework.stereotype.Service;
  22. import org.springframework.transaction.annotation.Transactional;
  23. import org.springframework.util.CollectionUtils;
  24. import java.util.*;
  25. import java.util.stream.Collectors;
  26. /**
  27. * <p>
  28. * 服务实现类
  29. * </p>
  30. *
  31. * @author
  32. * @since 2022-10-09
  33. */
  34. @RefreshScope
  35. @Service
  36. @Slf4j
  37. public class SceneCleanServiceImpl extends ServiceImpl<ISceneCleanMapper, SceneClean> implements ISceneCleanService {
  38. @Autowired
  39. private RedisLockUtil redisLockUtil;
  40. @Value("${scene.clean.size:10}")
  41. private Integer sceneCleanSize;
  42. @Transactional
  43. @Override
  44. public void sceneCleanResource(){
  45. // 获取redis 锁
  46. boolean lock = redisLockUtil.lock(RedisLockKey.LOCK_SCENE_CLEAN, RedisKey.EXPIRE_TIME_2_HOUR);
  47. if(!lock){
  48. log.warn("未获取到清除资源锁,退出任务!");
  49. return;
  50. }
  51. Date time = DateUtil.delay(Calendar.getInstance().getTime(), -7, Calendar.MONTH);
  52. time.setHours(0);
  53. time.setMinutes(0);
  54. time.setSeconds(0);
  55. //查询需要清理资源的场景
  56. List<SceneBean> sceneProEntityList = selectNeadCleanScene(0,sceneCleanSize, time);
  57. //如果查出来的场景集合是空,证明已经没有场景资源需要删除,则需要把查询下表删除,等待下一次定时任务执行
  58. if (CollectionUtils.isEmpty(sceneProEntityList)) {
  59. return;
  60. }
  61. List<String> numList = sceneProEntityList.parallelStream().map(SceneBean::getNum).collect(Collectors.toList());
  62. List<SceneClean> insertList = new ArrayList<>();
  63. List<SceneClean> updateList = this.list(new LambdaQueryWrapper<SceneClean>().in(SceneClean::getNum, numList));
  64. Set<String> updateSet = updateList.stream().map(SceneClean::getNum).collect(Collectors.toSet());
  65. sceneProEntityList.stream().forEach(scene -> {
  66. if (StringUtils.isNotBlank(scene.getDataSource())) {
  67. // 查询该资源的最新计算时间
  68. List<SceneClean> scenes = findAllByDateSource(scene.getDataSource());
  69. if (scenes.get(0).getCreateTime().before(time)) {
  70. try {
  71. CreateObjUtil.deleteFile(scene.getDataSource().replace(ConstantFilePath.BUILD_MODEL_PATH, "/").replace(ConstantFilePath.BUILD_MODEL_LASER_PATH, "/"));
  72. } catch (Exception e) {
  73. e.printStackTrace();
  74. updateSet.remove(scene.getNum());
  75. return;
  76. }
  77. }
  78. }
  79. if (!updateSet.contains(scene.getNum())) {
  80. SceneClean sceneCleanEntity = new SceneClean();
  81. sceneCleanEntity.setState(1);
  82. sceneCleanEntity.setNum(scene.getNum());
  83. sceneCleanEntity.setCreateTime(new Date());
  84. sceneCleanEntity.setUpdateTime(new Date());
  85. sceneCleanEntity.setRecStatus("A");
  86. insertList.add(sceneCleanEntity);
  87. }
  88. });
  89. //写库
  90. if(!CollectionUtils.isEmpty(insertList)){
  91. this.saveBatch(insertList);
  92. }
  93. if(!CollectionUtils.isEmpty(updateSet)){
  94. this.update(new LambdaUpdateWrapper<SceneClean>().set(SceneClean::getState,
  95. CommonStatus.YES.code()).in(SceneClean::getNum, updateSet));
  96. }
  97. redisLockUtil.unlock(RedisLockKey.LOCK_SCENE_CLEAN);
  98. }
  99. private List<SceneClean> findAllByDateSource(String dataSource) {
  100. return this.baseMapper.findAllByDateSource(dataSource);
  101. }
  102. @Override
  103. public List<SceneBean> selectNeadCleanScene(long index, int size, Date time) {
  104. return this.baseMapper.selectNeadCleanScene(index, size, time);
  105. }
  106. }