From e3307d42a20a6f6305cb55b559a0065db3cebc75 Mon Sep 17 00:00:00 2001 From: zhoushihao <zsh19950802@163.com> Date: 星期三, 20 十一月 2024 08:41:14 +0800 Subject: [PATCH] 1、大理片笼历史任务功能开发 2、大理片笼任务表4张、历史任务表一张脚本 3、大理片笼进片任务功能开发 4、解决卧理生产中遇到的bug --- hangzhoumesParent/moduleService/CacheVerticalGlassModule/src/main/java/com/mes/job/OpcPlcStorageCageTask.java | 501 ++++++++++++++++++++++++++++++------------------------- 1 files changed, 272 insertions(+), 229 deletions(-) diff --git a/hangzhoumesParent/moduleService/CacheVerticalGlassModule/src/main/java/com/mes/job/OpcPlcStorageCageTask.java b/hangzhoumesParent/moduleService/CacheVerticalGlassModule/src/main/java/com/mes/job/OpcPlcStorageCageTask.java index 2284d1e..6ac731b 100644 --- a/hangzhoumesParent/moduleService/CacheVerticalGlassModule/src/main/java/com/mes/job/OpcPlcStorageCageTask.java +++ b/hangzhoumesParent/moduleService/CacheVerticalGlassModule/src/main/java/com/mes/job/OpcPlcStorageCageTask.java @@ -3,37 +3,32 @@ import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; import com.baomidou.mybatisplus.core.toolkit.CollectionUtils; +import com.kangaroohy.milo.model.ReadWriteEntity; +import com.kangaroohy.milo.service.MiloService; import com.mes.bigstorage.entity.BigStorageCage; import com.mes.bigstorage.entity.BigStorageCageDetails; import com.mes.bigstorage.entity.BigStorageDTO; import com.mes.bigstorage.service.BigStorageCageDetailsService; import com.mes.bigstorage.service.BigStorageCageService; -import com.mes.bigstoragecageIntask.entity.BigStorageCageInTask; -import com.mes.bigstoragecageIntask.service.BigStorageCageInTaskService; -import com.mes.bigstoragetask.entity.BigStorageCageFeedTask; -import com.mes.bigstoragetask.entity.BigStorageCageOutTask; +import com.mes.bigstoragecagetask.entity.BigStorageCageHistoryTask; +import com.mes.bigstoragecagetask.entity.BigStorageCageTask; +import com.mes.bigstoragecagetask.service.BigStorageCageHistoryTaskService; +import com.mes.bigstoragecagetask.service.BigStorageCageTaskService; import com.mes.bigstoragetask.entity.UpdateBigStorageCageDTO; -import com.mes.bigstoragetask.service.BigStorageCageFeedTaskService; -import com.mes.bigstoragetask.service.BigStorageCageOutTaskService; import com.mes.common.config.Const; -import com.mes.damage.entity.Damage; import com.mes.damage.service.DamageService; import com.mes.glassinfo.entity.GlassInfo; import com.mes.glassinfo.service.GlassInfoService; -import com.mes.temperingglass.entity.TemperingGlassInfo; import com.mes.temperingglass.service.TemperingGlassInfoService; -import com.mes.tools.service.BigStorageBaseService; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.BeanUtils; +import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Value; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; import javax.annotation.Resource; -import java.util.ArrayList; -import java.util.Date; -import java.util.List; -import java.util.Map; +import java.util.*; import java.util.stream.Collectors; /** @@ -45,10 +40,6 @@ @Resource private BigStorageCageDetailsService bigStorageCageDetailsService; @Resource - private BigStorageCageFeedTaskService bigStorageCageFeedTaskService; - @Resource - private BigStorageCageOutTaskService bigStorageCageOutTaskService; - @Resource private TemperingGlassInfoService temperingGlassInfoService; @Resource private DamageService damageService; @@ -57,49 +48,43 @@ private GlassInfoService glassInfoService; @Resource private BigStorageCageService bigStorageCageService; + @Resource + private BigStorageCageHistoryTaskService bigStorageCageHistoryTaskService; + @Resource + private BigStorageCageTaskService bigStorageCageTaskService; - @Resource - private BigStorageBaseService baseService; - @Resource - private BigStorageCageInTaskService bigStorageBaseInTaskService; + @Autowired(required = false) + MiloService miloService; + + @Value("${mes.slotWidth}") + private Integer slotWidth; @Value("${mes.glassGap}") private Integer glassGap; -// @Resource -// private BigStorageCage bigStorageBaseInTaskService; - -// @Autowired(required = false) -// MiloService miloService; -// -// @Resource(name = "bigStorageStartCallback") -// SubscriptionCallback bigStorageStartCallback; - - -// @Scheduled(fixedDelay = Long.MAX_VALUE) -// public void startOpcTask() throws Exception { -// //璁惧涓�浜岀殑杩涚墖璇锋眰 -// miloService.subscriptionFromOpcUa(Arrays.asList("my.device01.x1", "my.device02.x1"), bigStorageStartCallback); -// } - -// @Scheduled(fixedDelay = Long.MAX_VALUE) -// public void outOpcTask() throws Exception { -// //璁惧1鐨勫嚭鐗囪姹� -// miloService.subscriptionFromOpcUa(Arrays.asList("my.device03.x1"), bigStorageStartCallback); -// } - - - @Scheduled(fixedDelay = 200) - public void inBigStorageTask() { - //todo:鑾峰彇杩涚墖浠诲姟琛� - List<BigStorageCageInTask> inTaskList = bigStorageBaseInTaskService.queryTaskMessage("big_storage_cage_in_one_task"); - if (CollectionUtils.isEmpty(inTaskList)) { - log.info("褰撳墠澶ц溅鏃犺繘鐗囦换鍔★紝缁撴潫鏈湴瀹氭椂浠诲姟"); + @Scheduled(fixedDelay = 1000) + public void inBigStorageTask() throws Exception { + ReadWriteEntity inkageEntity = miloService.readFromOpcUa("PLC.DPL1.inkageState"); + if (!"1".equals(inkageEntity.getValue())) { + log.info("褰撳墠涓洪潪鑱旀満鐘舵�侊紝缁撴潫杩涚墖浠诲姟"); + return; } - List<String> glassIdList = inTaskList.stream().map(BigStorageCageInTask::getGlassId).collect(Collectors.toList()); - Map<String, List<BigStorageCageInTask>> taskMap = inTaskList.stream().collect(Collectors.groupingBy(BigStorageCageInTask::getGlassId)); + ReadWriteEntity requestEntity = miloService.readFromOpcUa("PLC.DPL1.plcInGlassRequest"); + if (!"1".equals(requestEntity.getValue())) { + log.info("褰撳墠鏈敹鍒拌繘鐗囪姹傦紝缁撴潫杩涚墖浠诲姟"); + return; + } + //鑾峰彇杩涚墖浠诲姟琛� + List<BigStorageCageTask> inTaskList = bigStorageCageTaskService.queryTaskMessage("big_storage_cage_in_one_task"); + if (CollectionUtils.isEmpty(inTaskList)) { + log.info("褰撳墠澶ц溅鏃犺繘鐗囩幓鐠冿紝缁撴潫杩涚墖浠诲姟"); + } + List<String> glassIdList = inTaskList.stream().map(BigStorageCageTask::getGlassId).collect(Collectors.toList()); + log.info("鑾峰彇浠诲姟鐨勭幓鐠僫d锛歿}", glassIdList); + Map<String, List<BigStorageCageTask>> taskMap = inTaskList.stream().collect(Collectors.groupingBy(BigStorageCageTask::getGlassId)); List<GlassInfo> glassInfoList = glassInfoService.list(new LambdaQueryWrapper<GlassInfo>().in(GlassInfo::getGlassId, glassIdList)); - //todo:璁$畻鐩爣鏍煎瓙 + //璁$畻鐩爣鏍煎瓙 + List<BigStorageCageHistoryTask> historyTasks = new ArrayList<>(); for (GlassInfo info : glassInfoList) { //鑾峰彇鐩爣鏍煎瓙淇℃伅 BigStorageDTO bigStorageDTO = bigStorageCageDetailsService.queryTargetSlotByTempering(info); @@ -107,198 +92,256 @@ bigStorageCageService.update(new LambdaUpdateWrapper<BigStorageCage>() .set(BigStorageCage::getRemainWidth, bigStorageDTO.getWidth() - Math.max(info.getWidth(), info.getHeight()) - glassGap) .eq(BigStorageCage::getSlot, bigStorageDTO.getSlot())); - BigStorageCageInTask task = taskMap.get(info.getGlassId()).get(0); + BigStorageCageTask task = taskMap.get(info.getGlassId()).get(0); task.setTargetSlot(bigStorageDTO.getSlot()); task.setGlassId(info.getGlassId()); - task.setTaskRunning(Const.BIG_STORAGE_TASK_RUNNING); - bigStorageBaseInTaskService.updateTaskMessage("", task); - //todo:瀛樻斁鍘嗗彶浠诲姟 - } + bigStorageCageTaskService.updateTaskMessage("big_storage_cage_in_one_task", task); + //瀛樻斁鍘嗗彶浠诲姟 + BigStorageCageHistoryTask historyTask = new BigStorageCageHistoryTask(); + BeanUtils.copyProperties(task, historyTask); + historyTask.setTaskType(Const.BIG_STORAGE_BEFORE_IN); + historyTask.setGlassCount(glassInfoList.size()); + historyTask.setTaskState(Const.ENGINEERING_NEW); + BigStorageCageDetails cageDetails = new BigStorageCageDetails(); + BeanUtils.copyProperties(info, cageDetails); + cageDetails.setSlot(bigStorageDTO.getSlot()); + cageDetails.setState(Const.GLASS_STATE_NEW); + cageDetails.setDeviceId(bigStorageDTO.getDeviceId()); + cageDetails.setGap(glassGap); + bigStorageCageDetailsService.save(cageDetails); + } + //鍘嗗彶鏁版嵁鍏ュ簱 + bigStorageCageHistoryTaskService.saveBatch(historyTasks); + //鍚憃pc鍙戦�佸惎鍔ㄤ俊鍙� + miloService.writeToOpcWord(generateReadWriteEntity("PLC.DPL1.taskRunning", 1)); } - - @Scheduled(fixedDelay = 300) - public void updateInGlassStateTask() { - Date startDate = new Date(); - log.info("1銆佸ぇ鐞嗙墖绗艰繘鐗囧畬鎴愬悗鏇存柊澶х悊鐗囩鏁版嵁浠诲姟寮�濮嬫墽琛屾椂闂达細{}", startDate); - //鍥犱负澶х悊鐗囩鍜屽嚭鐗囦换鍔℃槸涓や釜搴撶殑鏁版嵁锛屾墍浠ヨ鍒嗗紑鏌ユ壘 - List<Object> list = bigStorageCageDetailsService.listObjs(new LambdaQueryWrapper<BigStorageCageDetails>() - .select(BigStorageCageDetails::getGlassId).eq(BigStorageCageDetails::getState, Const.GLASS_STATE_NEW)); - if (CollectionUtils.isNotEmpty(list)) { - log.info("2銆佽幏鍙栨墍鏈夋鍦ㄨ繘鐗囩殑鐜荤拑淇℃伅id:{}", list); - List<String> glassIds = list.stream().map(String::valueOf).collect(Collectors.toList()); - List<BigStorageCageFeedTask> inSuccessGlass = bigStorageCageFeedTaskService.list(new LambdaQueryWrapper<BigStorageCageFeedTask>() - .in(BigStorageCageFeedTask::getGlassId, glassIds) - .in(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_SLOT)); - if (CollectionUtils.isNotEmpty(inSuccessGlass)) { - log.info("3銆佽幏鍙栬繘鐗囧凡瀹屾垚鐨勭幓鐠冧俊鎭痠d:{}", inSuccessGlass); - List<Integer> inSuccessGlassSlot = inSuccessGlass.stream().map(BigStorageCageFeedTask::getTargetSlot).collect(Collectors.toList()); - List<UpdateBigStorageCageDTO> storageCageDTOList = inSuccessGlass.stream().map(e -> { + @Scheduled(fixedDelay = 1000) + public void finishBigStorageTask() throws Exception { + ReadWriteEntity inkageEntity = miloService.readFromOpcUa("PLC.DPL1.inkageState"); + if (!"1".equals(inkageEntity.getValue())) { + log.info("褰撳墠涓洪潪鑱旀満鐘舵�侊紝缁撴潫瀹屾垚杩涚墖浠诲姟"); + return; + } + //鑾峰彇杩涚墖浠诲姟琛� + List<BigStorageCageTask> inTaskList = bigStorageCageTaskService.queryTaskMessage("big_storage_cage_in_one_task"); + if (CollectionUtils.isEmpty(inTaskList)) { + log.info("褰撳墠澶ц溅鏃犺繘鐗囩幓鐠冿紝缁撴潫瀹屾垚杩涚墖浠诲姟"); + } + List<BigStorageCageTask> unFinishTaskList = inTaskList.stream().filter(e -> e.getTaskState() <= 1).collect(Collectors.toList()); + if (CollectionUtils.isNotEmpty(unFinishTaskList)) { + log.info("瀛樺湪鏈畬鎴愮殑鐜荤拑淇℃伅,鐜荤拑锛歿}", unFinishTaskList); + return; + } + Map<Integer, List<BigStorageCageTask>> taskMap = inTaskList.stream().collect(Collectors.groupingBy(BigStorageCageTask::getTaskState)); + //鎸夌収浠诲姟鐘舵�佷慨鏀瑰ぇ鐞嗙墖绗煎唴鐨勭幓鐠冩暟鎹� + taskMap.forEach((e1, v) -> { + List<String> glassList = v.stream().map(BigStorageCageTask::getGlassId).collect(Collectors.toList()); + if (e1 == 2) { + //杩涚墖瀹屾垚 + log.info("3銆佽幏鍙栬繘鐗囧凡瀹屾垚鐨勭幓鐠冧俊鎭痠d:{}", v); + List<Integer> inSuccessGlassSlot = v.stream().map(BigStorageCageTask::getTargetSlot).collect(Collectors.toList()); + List<UpdateBigStorageCageDTO> storageCageDTOList = v.stream().map(e -> { UpdateBigStorageCageDTO storageCageDTO = new UpdateBigStorageCageDTO(); BeanUtils.copyProperties(e, storageCageDTO); return storageCageDTO; }).collect(Collectors.toList()); bigStorageCageDetailsService.updateBySlot(storageCageDTOList, Const.GLASS_STATE_IN); - log.info("4銆佸ぇ鐞嗙墖绗艰繘鐗囩姸鎬佸凡瀹屾垚宸插畬鎴愮殑鐜荤拑淇℃伅id:{}", inSuccessGlass); - //鏇存柊鐞嗙墖绗肩幓鐠冨昂瀵� - baseService.updateSlotRemainBySlots(inSuccessGlassSlot); - log.info("5銆佸ぇ鐞嗙墖绗艰繘鐗囩洰鏍囨牸瀛愬昂瀵告洿鏂板畬鎴�"); + log.info("4銆佸ぇ鐞嗙墖绗艰繘鐗囩姸鎬佸凡瀹屾垚宸插畬鎴愮殑鐜荤拑淇℃伅id:{}", v); + updateSlotRemainBySlots(inSuccessGlassSlot); + } else if (e1 == 3) { + //鐮存崯澶勭悊 + } else { + //娓呯┖鐞嗙墖绗肩┖鏁版嵁 } - - } - Date endDate = new Date(); - log.info("end:澶х悊鐗囩杩涚墖瀹屾垚鍚庢洿鏂板ぇ鐞嗙墖绗兼暟鎹换鍔$粨鏉熸椂闂达細{}锛屽叡鑰楁椂锛歿}ms,缁撴潫浠诲姟", endDate, endDate.getTime() - startDate.getTime()); - return; + }); + //todo:鎸夌収浠诲姟鐘舵�佷慨鏀瑰ぇ鐞嗙墖绗煎唴鐨勭幓鐠冩暟鎹� + //todo:閲嶆柊璁$畻澶х悊鐗囩鍐呯殑鍓╀綑灏哄 + //todo:鏇存柊鍘嗗彶浠诲姟琛ㄤ腑鐨勪换鍔$姸鎬� + //todo:娓呯┖浠诲姟琛ㄦ暟鎹� + //todo:娓呯┖鍚姩鐘舵�� } - @Scheduled(fixedDelay = 300) - public void updateOutGlassStateTask() { - Date startDate = new Date(); - log.info("1銆佸ぇ鐞嗙墖绗煎嚭鐗囧畬鎴愬悗鏇存柊澶х悊鐗囩鏁版嵁浠诲姟寮�濮嬫墽琛屾椂闂达細{}", startDate); - //鍥犱负澶х悊鐗囩鍜屽嚭鐗囦换鍔℃槸涓や釜搴撶殑鏁版嵁锛屾墍浠ヨ鍒嗗紑鏌ユ壘 - List<Object> list = bigStorageCageDetailsService.listObjs(new LambdaQueryWrapper<BigStorageCageDetails>() - .select(BigStorageCageDetails::getGlassId).eq(BigStorageCageDetails::getState, Const.GLASS_STATE_OUT_ING)); - if (CollectionUtils.isNotEmpty(list)) { - log.info("2銆佽幏鍙栨墍鏈夋鍦ㄥ嚭鐗囩殑鐜荤拑淇℃伅id:{}", list); - List<String> glassIds = list.stream().map(String::valueOf).collect(Collectors.toList()); - List<BigStorageCageOutTask> outSuccessGlass = bigStorageCageOutTaskService.list(new LambdaQueryWrapper<BigStorageCageOutTask>() - .in(BigStorageCageOutTask::getGlassId, glassIds).in(BigStorageCageOutTask::getTaskState, Const.BIG_STORAGE_OUT_ALL)); - if (CollectionUtils.isNotEmpty(outSuccessGlass)) { - for (BigStorageCageOutTask bigStorageCageOutTask : outSuccessGlass - ) { - if (bigStorageCageOutTask.getEndSlot().equals(Const.ARTIFICIAL_OUT_TARGET_POSITION)) { - temperingGlassInfoService.update( - new LambdaUpdateWrapper<TemperingGlassInfo>() - .set(TemperingGlassInfo::getState, Const.TEMPERING_END) - .eq(TemperingGlassInfo::getGlassId, bigStorageCageOutTask.getGlassId()) - ); - } - } - log.info("3銆佽幏鍙栧嚭鐗囧凡瀹屾垚鐨勭幓鐠冧俊鎭痠d:{}", outSuccessGlass); - List<UpdateBigStorageCageDTO> storageCageDTOList = outSuccessGlass.stream().map(e -> { - UpdateBigStorageCageDTO storageCageDTO = new UpdateBigStorageCageDTO(); - storageCageDTO.setGlassId(e.getGlassId()); - storageCageDTO.setTargetSlot(e.getStartSlot()); - return storageCageDTO; - }).collect(Collectors.toList()); - bigStorageCageDetailsService.updateBySlot(storageCageDTOList, Const.GLASS_STATE_OUT); - List<Integer> outSuccessSlotList = outSuccessGlass.stream().map(BigStorageCageOutTask::getStartSlot).collect(Collectors.toList()); - log.info("4銆佸ぇ鐞嗙墖绗煎嚭鐗囩姸鎬佸凡瀹屾垚宸插畬鎴愮殑鐜荤拑淇℃伅id:{}", outSuccessGlass); - //鏇存柊鐞嗙墖绗肩幓鐠冨昂瀵� - baseService.updateSlotRemainBySlots(outSuccessSlotList); - log.info("5銆佸ぇ鐞嗙墖绗艰繘鐗囩洰鏍囨牸瀛愬昂瀵告洿鏂板畬鎴�"); - } - } - Date endDate = new Date(); - log.info("end:澶х悊鐗囩鍑虹墖瀹屾垚鍚庢洿鏂板ぇ鐞嗙墖绗兼暟鎹换鍔$粨鏉熸椂闂达細{}锛屽叡鑰楁椂锛歿}ms,缁撴潫浠诲姟", endDate, endDate.getTime() - startDate.getTime()); - return; +// +// @Scheduled(fixedDelay = 300) +// public void updateOutGlassStateTask() { +// Date startDate = new Date(); +// log.info("1銆佸ぇ鐞嗙墖绗煎嚭鐗囧畬鎴愬悗鏇存柊澶х悊鐗囩鏁版嵁浠诲姟寮�濮嬫墽琛屾椂闂达細{}", startDate); +// //鍥犱负澶х悊鐗囩鍜屽嚭鐗囦换鍔℃槸涓や釜搴撶殑鏁版嵁锛屾墍浠ヨ鍒嗗紑鏌ユ壘 +// List<Object> list = bigStorageCageDetailsService.listObjs(new LambdaQueryWrapper<BigStorageCageDetails>() +// .select(BigStorageCageDetails::getGlassId).eq(BigStorageCageDetails::getState, Const.GLASS_STATE_OUT_ING)); +// if (CollectionUtils.isNotEmpty(list)) { +// log.info("2銆佽幏鍙栨墍鏈夋鍦ㄥ嚭鐗囩殑鐜荤拑淇℃伅id:{}", list); +// List<String> glassIds = list.stream().map(String::valueOf).collect(Collectors.toList()); +// List<BigStorageCageOutTask> outSuccessGlass = bigStorageCageOutTaskService.list(new LambdaQueryWrapper<BigStorageCageOutTask>() +// .in(BigStorageCageOutTask::getGlassId, glassIds).in(BigStorageCageOutTask::getTaskState, Const.BIG_STORAGE_OUT_ALL)); +// if (CollectionUtils.isNotEmpty(outSuccessGlass)) { +// for (BigStorageCageOutTask bigStorageCageOutTask : outSuccessGlass +// ) { +// if (bigStorageCageOutTask.getEndSlot().equals(Const.ARTIFICIAL_OUT_TARGET_POSITION)) { +// temperingGlassInfoService.update( +// new LambdaUpdateWrapper<TemperingGlassInfo>() +// .set(TemperingGlassInfo::getState, Const.TEMPERING_END) +// .eq(TemperingGlassInfo::getGlassId, bigStorageCageOutTask.getGlassId()) +// ); +// } +// } +// log.info("3銆佽幏鍙栧嚭鐗囧凡瀹屾垚鐨勭幓鐠冧俊鎭痠d:{}", outSuccessGlass); +// List<UpdateBigStorageCageDTO> storageCageDTOList = outSuccessGlass.stream().map(e -> { +// UpdateBigStorageCageDTO storageCageDTO = new UpdateBigStorageCageDTO(); +// storageCageDTO.setGlassId(e.getGlassId()); +// storageCageDTO.setTargetSlot(e.getStartSlot()); +// return storageCageDTO; +// }).collect(Collectors.toList()); +// bigStorageCageDetailsService.updateBySlot(storageCageDTOList, Const.GLASS_STATE_OUT); +// List<Integer> outSuccessSlotList = outSuccessGlass.stream().map(BigStorageCageOutTask::getStartSlot).collect(Collectors.toList()); +// log.info("4銆佸ぇ鐞嗙墖绗煎嚭鐗囩姸鎬佸凡瀹屾垚宸插畬鎴愮殑鐜荤拑淇℃伅id:{}", outSuccessGlass); +// //鏇存柊鐞嗙墖绗肩幓鐠冨昂瀵� +// baseService.updateSlotRemainBySlots(outSuccessSlotList); +// log.info("5銆佸ぇ鐞嗙墖绗艰繘鐗囩洰鏍囨牸瀛愬昂瀵告洿鏂板畬鎴�"); +// } +// } +// Date endDate = new Date(); +// log.info("end:澶х悊鐗囩鍑虹墖瀹屾垚鍚庢洿鏂板ぇ鐞嗙墖绗兼暟鎹换鍔$粨鏉熸椂闂达細{}锛屽叡鑰楁椂锛歿}ms,缁撴潫浠诲姟", endDate, endDate.getTime() - startDate.getTime()); +// return; +// +// } +// +// @Scheduled(fixedDelay = 300) +// public void updateScheduleGlassStateTask() { +// Date startDate = new Date(); +// log.info("1銆佸ぇ鐞嗙墖绗艰皟搴﹀畬鎴愬悗鏇存柊澶х悊鐗囩鏁版嵁浠诲姟寮�濮嬫墽琛屾椂闂达細{}", startDate); +// //鍥犱负澶х悊鐗囩鍜岃皟搴︿换鍔℃槸涓や釜搴撶殑鏁版嵁锛屾墍浠ヨ鍒嗗紑鏌ユ壘 +// List<Object> list = bigStorageCageDetailsService.listObjs(new LambdaQueryWrapper<BigStorageCageDetails>() +// .select(BigStorageCageDetails::getGlassId).eq(BigStorageCageDetails::getState, Const.GLASS_STATE_SCHEDULE_ING)); +// if (CollectionUtils.isNotEmpty(list)) { +// log.info("2銆佽幏鍙栨墍鏈夋鍦ㄥ嚭鐗囩殑鐜荤拑淇℃伅id:{}", list); +// List<String> glassIds = list.stream().map(String::valueOf).collect(Collectors.toList()); +// List<BigStorageCageOutTask> scheduleSuccessGlass = bigStorageCageOutTaskService.list(new LambdaQueryWrapper<BigStorageCageOutTask>() +// .in(BigStorageCageOutTask::getGlassId, glassIds).eq(BigStorageCageOutTask::getTaskState, Const.BIG_STORAGE_OUT_SUCCESS) +// .notIn(BigStorageCageOutTask::getEndSlot, Const.TEMPERING_OUT_TARGET_POSITION, Const.ARTIFICIAL_OUT_TARGET_POSITION)); +// if (CollectionUtils.isNotEmpty(scheduleSuccessGlass)) { +// log.info("3銆佽幏鍙栬皟搴﹀凡瀹屾垚鐨勭幓鐠冧俊鎭痠d:{}", scheduleSuccessGlass); +// List<UpdateBigStorageCageDTO> storageCageDTOList = scheduleSuccessGlass.stream().map(e -> { +// UpdateBigStorageCageDTO storageCageDTO = new UpdateBigStorageCageDTO(); +// storageCageDTO.setGlassId(e.getGlassId()); +// storageCageDTO.setTargetSlot(e.getEndSlot()); +// return storageCageDTO; +// }).collect(Collectors.toList()); +// bigStorageCageDetailsService.updateBySlot(storageCageDTOList, Const.GLASS_STATE_IN); +// List<String> scheduleSuccessGlassIds = scheduleSuccessGlass.stream().map(BigStorageCageOutTask::getGlassId).collect(Collectors.toList()); +// log.info("4銆佸ぇ鐞嗙墖绗煎嚭鐗囩姸鎬佸凡瀹屾垚宸插畬鎴愮殑鐜荤拑淇℃伅id:{}", scheduleSuccessGlassIds); +// //鏇存柊鐞嗙墖绗肩幓鐠冨昂瀵� +// List<Integer> slotList = scheduleSuccessGlass.stream().map(BigStorageCageOutTask::getStartSlot).distinct().collect(Collectors.toList()); +// slotList.addAll(scheduleSuccessGlass.stream().map(BigStorageCageOutTask::getEndSlot).distinct().collect(Collectors.toList())); +// baseService.updateSlotRemainBySlots(slotList); +// log.info("5銆佸ぇ鐞嗙墖绗艰繘鐗囩洰鏍囨牸瀛愬昂瀵告洿鏂板畬鎴�"); +// } +// } +// Date endDate = new Date(); +// log.info("end:澶х悊鐗囩鍑虹墖瀹屾垚鍚庢洿鏂板ぇ鐞嗙墖绗兼暟鎹换鍔$粨鏉熸椂闂达細{}锛屽叡鑰楁椂锛歿}ms,缁撴潫浠诲姟", endDate, endDate.getTime() - startDate.getTime()); +// return; +// +// } +// +// /** +// * 澶勭悊鐮存崯琛ㄤ换鍔� +// */ +// @Scheduled(fixedDelay = 300) +// public void dealDamageTask() { +// Date startDate = new Date(); +// log.info("澶х悊鐗囩鐮存崯鐜荤拑娓呴櫎浠诲姟寮�濮嬫墽琛屾椂闂达細{}", startDate); +// //鑾峰彇杩涚墖浠诲姟琛ㄤ腑鐘舵�佷负鐮存崯鐨勬暟鎹� +// List<BigStorageCageFeedTask> inDamageTaskInfoList = bigStorageCageFeedTaskService.list(new LambdaQueryWrapper<BigStorageCageFeedTask>() +// .in(BigStorageCageFeedTask::getTaskState, Const.GLASS_STATE_DAMAGE_TAKE)); +// if (CollectionUtils.isNotEmpty(inDamageTaskInfoList)) { +// log.info("鑾峰彇杩涚墖浠诲姟琛ㄤ腑鐮存崯鐨勭幓鐠冧俊鎭瘂}", inDamageTaskInfoList); +// bigStorageCageFeedTaskService.remove(new LambdaQueryWrapper<BigStorageCageFeedTask>().in(BigStorageCageFeedTask::getTaskState, Const.GLASS_STATE_DAMAGE_TAKE)); +// //鐞嗙墖绗艰鎯呰〃鏁版嵁鐘舵�佹洿鏂� +// bigStorageCageDetailsService.remove(new LambdaQueryWrapper<BigStorageCageDetails>() +// .eq(BigStorageCageDetails::getState, Const.GLASS_STATE_NEW).in(BigStorageCageDetails::getGlassId, inDamageTaskInfoList.stream().map(BigStorageCageFeedTask::getGlassId).collect(Collectors.toList()))); +// //灏嗙牬鎹熶俊鎭柊澧炲叆鐮存崯琛� +// List<Integer> slotList = new ArrayList<>(); +// for (BigStorageCageFeedTask bigStorageCageFeedTask : inDamageTaskInfoList) { +// Damage damage = new Damage(); +// damage.setGlassId(bigStorageCageFeedTask.getGlassId()); +// damage.setLine(bigStorageCageFeedTask.getLine()); +// damage.setWorkingProcedure("纾ㄨ竟"); +// damage.setRemark("杩涚鍓嶅崸杞珛"); +// damage.setStatus(1); +// damage.setType(bigStorageCageFeedTask.getTaskState()); +// damageService.insertDamage(damage); +// slotList.add(bigStorageCageFeedTask.getTargetSlot()); +// } +// //鏇存柊鏍煎瓙鍓╀綑瀹藉害 +// baseService.updateSlotRemainBySlots(slotList); +// log.info("杩涚墖浠诲姟鎵ц瀹屾垚"); +// } +// //鑾峰彇鍑虹墖浠诲姟琛ㄤ腑鐘舵�佷负鐮存崯鐨勬暟鎹� +// List<BigStorageCageOutTask> outDamageTaskInfoList = bigStorageCageOutTaskService.list(new LambdaQueryWrapper<BigStorageCageOutTask>() +// .in(BigStorageCageOutTask::getTaskState, Const.GLASS_STATE_DAMAGE_TAKE)); +// if (CollectionUtils.isNotEmpty(outDamageTaskInfoList)) { +// log.info("鑾峰彇鍑虹墖浠诲姟琛ㄤ腑鐮存崯鐨勭幓鐠冧俊鎭瘂}", outDamageTaskInfoList); +// bigStorageCageOutTaskService.remove(new LambdaQueryWrapper<BigStorageCageOutTask>().in(BigStorageCageOutTask::getTaskState, Const.GLASS_STATE_DAMAGE_TAKE)); +// List<String> glassIdList = outDamageTaskInfoList.stream().map(BigStorageCageOutTask::getGlassId).collect(Collectors.toList()); +// //绉婚櫎閽㈠寲涓嬬墖琛ㄦ暟鎹� +// temperingGlassInfoService.remove(new LambdaQueryWrapper<TemperingGlassInfo>().in(TemperingGlassInfo::getGlassId, glassIdList)); +// //鐞嗙墖绗艰鎯呰〃鏁版嵁鐘舵�佸垹闄� +// bigStorageCageDetailsService.remove(new LambdaQueryWrapper<BigStorageCageDetails>().in(BigStorageCageDetails::getGlassId, glassIdList)); +// //灏嗙牬鎹熶俊鎭柊澧炲叆鐮存崯琛� +// List<Integer> slotList = new ArrayList<>(); +// for (BigStorageCageOutTask bigStorageCageOutTask : outDamageTaskInfoList) { +// Damage damage = new Damage(); +// damage.setGlassId(bigStorageCageOutTask.getGlassId()); +// damage.setLine(bigStorageCageOutTask.getEndSlot()); +// damage.setWorkingProcedure("閽㈠寲"); +// damage.setRemark("鍑虹墖鍚庡崸杞珛"); +// damage.setStatus(1); +// damage.setType(bigStorageCageOutTask.getTaskState()); +// damageService.insertDamage(damage); +// slotList.add(bigStorageCageOutTask.getStartSlot()); +// } +// //鏇存柊鏍煎瓙鍓╀綑瀹藉害 +// baseService.updateSlotRemainBySlots(slotList); +// log.info("鍑虹墖浠诲姟鎵ц瀹屾垚"); +// } +// Date endDate = new Date(); +// log.info("澶х悊鐗囩鐮存崯鐜荤拑娓呴櫎浠诲姟缁撴潫鏃堕棿锛歿}锛屽叡鑰楁椂锛歿}ms,缁撴潫鎵爜浠诲姟", endDate, endDate.getTime() - startDate.getTime()); +// return; +// } + public void updateSlotRemainBySlots(List<Integer> slotList) { + //鑾峰彇鏍煎瓙鍐呮墍鏈夌殑鐜荤拑淇℃伅 + List<BigStorageCageDetails> inSlotGlassList = bigStorageCageDetailsService.list(new LambdaQueryWrapper<BigStorageCageDetails>() + .in(BigStorageCageDetails::getSlot, slotList).in(BigStorageCageDetails::getState, Const.GLASS_STATE_IN_ALL)); + Map<Integer, Double> slotRemainMap = new HashMap<>(); + //鏄惁瀛樺湪鏈夋牸瀛愰潪绌虹殑鐜荤拑 + if (CollectionUtils.isNotEmpty(inSlotGlassList)) { + //瀛樺湪 灏嗘牸瀛愬唴鐨勭幓鐠冨垎鍒繘琛屾洿鏂� + slotRemainMap = inSlotGlassList.stream() + .collect(Collectors.groupingBy(BigStorageCageDetails::getSlot, Collectors.summingDouble(item -> Math.max(item.getWidth(), item.getHeight()) + glassGap))); + slotRemainMap.forEach((e, v) -> { + double remainWidth = slotWidth - v >= 0 ? slotWidth - v : 0; + bigStorageCageService.update(new LambdaUpdateWrapper<BigStorageCage>().set(BigStorageCage::getRemainWidth, remainWidth) + .eq(BigStorageCage::getSlot, e)); + }); + } + //杩囨护涓嶅瓨鍦ㄧ幓鐠冪殑鏍煎瓙 灏嗗搴﹂噸缃负鍘熷瀹藉害5000 + Set<Integer> remainSlotList = slotRemainMap.keySet(); + slotList.removeAll(remainSlotList); + if (CollectionUtils.isNotEmpty(slotList)) { + bigStorageCageService.update(new LambdaUpdateWrapper<BigStorageCage>().set(BigStorageCage::getRemainWidth, slotWidth) + .in(BigStorageCage::getSlot, slotList)); + } } - @Scheduled(fixedDelay = 300) - public void updateScheduleGlassStateTask() { - Date startDate = new Date(); - log.info("1銆佸ぇ鐞嗙墖绗艰皟搴﹀畬鎴愬悗鏇存柊澶х悊鐗囩鏁版嵁浠诲姟寮�濮嬫墽琛屾椂闂达細{}", startDate); - //鍥犱负澶х悊鐗囩鍜岃皟搴︿换鍔℃槸涓や釜搴撶殑鏁版嵁锛屾墍浠ヨ鍒嗗紑鏌ユ壘 - List<Object> list = bigStorageCageDetailsService.listObjs(new LambdaQueryWrapper<BigStorageCageDetails>() - .select(BigStorageCageDetails::getGlassId).eq(BigStorageCageDetails::getState, Const.GLASS_STATE_SCHEDULE_ING)); - if (CollectionUtils.isNotEmpty(list)) { - log.info("2銆佽幏鍙栨墍鏈夋鍦ㄥ嚭鐗囩殑鐜荤拑淇℃伅id:{}", list); - List<String> glassIds = list.stream().map(String::valueOf).collect(Collectors.toList()); - List<BigStorageCageOutTask> scheduleSuccessGlass = bigStorageCageOutTaskService.list(new LambdaQueryWrapper<BigStorageCageOutTask>() - .in(BigStorageCageOutTask::getGlassId, glassIds).eq(BigStorageCageOutTask::getTaskState, Const.BIG_STORAGE_OUT_SUCCESS) - .notIn(BigStorageCageOutTask::getEndSlot, Const.TEMPERING_OUT_TARGET_POSITION, Const.ARTIFICIAL_OUT_TARGET_POSITION)); - if (CollectionUtils.isNotEmpty(scheduleSuccessGlass)) { - log.info("3銆佽幏鍙栬皟搴﹀凡瀹屾垚鐨勭幓鐠冧俊鎭痠d:{}", scheduleSuccessGlass); - List<UpdateBigStorageCageDTO> storageCageDTOList = scheduleSuccessGlass.stream().map(e -> { - UpdateBigStorageCageDTO storageCageDTO = new UpdateBigStorageCageDTO(); - storageCageDTO.setGlassId(e.getGlassId()); - storageCageDTO.setTargetSlot(e.getEndSlot()); - return storageCageDTO; - }).collect(Collectors.toList()); - bigStorageCageDetailsService.updateBySlot(storageCageDTOList, Const.GLASS_STATE_IN); - List<String> scheduleSuccessGlassIds = scheduleSuccessGlass.stream().map(BigStorageCageOutTask::getGlassId).collect(Collectors.toList()); - log.info("4銆佸ぇ鐞嗙墖绗煎嚭鐗囩姸鎬佸凡瀹屾垚宸插畬鎴愮殑鐜荤拑淇℃伅id:{}", scheduleSuccessGlassIds); - //鏇存柊鐞嗙墖绗肩幓鐠冨昂瀵� - List<Integer> slotList = scheduleSuccessGlass.stream().map(BigStorageCageOutTask::getStartSlot).distinct().collect(Collectors.toList()); - slotList.addAll(scheduleSuccessGlass.stream().map(BigStorageCageOutTask::getEndSlot).distinct().collect(Collectors.toList())); - baseService.updateSlotRemainBySlots(slotList); - log.info("5銆佸ぇ鐞嗙墖绗艰繘鐗囩洰鏍囨牸瀛愬昂瀵告洿鏂板畬鎴�"); - } - } - Date endDate = new Date(); - log.info("end:澶х悊鐗囩鍑虹墖瀹屾垚鍚庢洿鏂板ぇ鐞嗙墖绗兼暟鎹换鍔$粨鏉熸椂闂达細{}锛屽叡鑰楁椂锛歿}ms,缁撴潫浠诲姟", endDate, endDate.getTime() - startDate.getTime()); - return; - + private ReadWriteEntity generateReadWriteEntity(String identifier, Object value) { + return ReadWriteEntity.builder() + .identifier(identifier) + //Kep涓槸Long绫诲瀷锛屽嵆锛欼nt32锛孞ava涓殑int绫诲瀷 + .value(value) + .build(); } - - /** - * 澶勭悊鐮存崯琛ㄤ换鍔� - */ - @Scheduled(fixedDelay = 300) - public void dealDamageTask() { - Date startDate = new Date(); - log.info("澶х悊鐗囩鐮存崯鐜荤拑娓呴櫎浠诲姟寮�濮嬫墽琛屾椂闂达細{}", startDate); - //鑾峰彇杩涚墖浠诲姟琛ㄤ腑鐘舵�佷负鐮存崯鐨勬暟鎹� - List<BigStorageCageFeedTask> inDamageTaskInfoList = bigStorageCageFeedTaskService.list(new LambdaQueryWrapper<BigStorageCageFeedTask>() - .in(BigStorageCageFeedTask::getTaskState, Const.GLASS_STATE_DAMAGE_TAKE)); - if (CollectionUtils.isNotEmpty(inDamageTaskInfoList)) { - log.info("鑾峰彇杩涚墖浠诲姟琛ㄤ腑鐮存崯鐨勭幓鐠冧俊鎭瘂}", inDamageTaskInfoList); - bigStorageCageFeedTaskService.remove(new LambdaQueryWrapper<BigStorageCageFeedTask>().in(BigStorageCageFeedTask::getTaskState, Const.GLASS_STATE_DAMAGE_TAKE)); - //鐞嗙墖绗艰鎯呰〃鏁版嵁鐘舵�佹洿鏂� - bigStorageCageDetailsService.remove(new LambdaQueryWrapper<BigStorageCageDetails>() - .eq(BigStorageCageDetails::getState, Const.GLASS_STATE_NEW).in(BigStorageCageDetails::getGlassId, inDamageTaskInfoList.stream().map(BigStorageCageFeedTask::getGlassId).collect(Collectors.toList()))); - //灏嗙牬鎹熶俊鎭柊澧炲叆鐮存崯琛� - List<Integer> slotList = new ArrayList<>(); - for (BigStorageCageFeedTask bigStorageCageFeedTask : inDamageTaskInfoList) { - Damage damage = new Damage(); - damage.setGlassId(bigStorageCageFeedTask.getGlassId()); - damage.setLine(bigStorageCageFeedTask.getLine()); - damage.setWorkingProcedure("纾ㄨ竟"); - damage.setRemark("杩涚鍓嶅崸杞珛"); - damage.setStatus(1); - damage.setType(bigStorageCageFeedTask.getTaskState()); - damageService.insertDamage(damage); - slotList.add(bigStorageCageFeedTask.getTargetSlot()); - } - //鏇存柊鏍煎瓙鍓╀綑瀹藉害 - baseService.updateSlotRemainBySlots(slotList); - log.info("杩涚墖浠诲姟鎵ц瀹屾垚"); - } - //鑾峰彇鍑虹墖浠诲姟琛ㄤ腑鐘舵�佷负鐮存崯鐨勬暟鎹� - List<BigStorageCageOutTask> outDamageTaskInfoList = bigStorageCageOutTaskService.list(new LambdaQueryWrapper<BigStorageCageOutTask>() - .in(BigStorageCageOutTask::getTaskState, Const.GLASS_STATE_DAMAGE_TAKE)); - if (CollectionUtils.isNotEmpty(outDamageTaskInfoList)) { - log.info("鑾峰彇鍑虹墖浠诲姟琛ㄤ腑鐮存崯鐨勭幓鐠冧俊鎭瘂}", outDamageTaskInfoList); - bigStorageCageOutTaskService.remove(new LambdaQueryWrapper<BigStorageCageOutTask>().in(BigStorageCageOutTask::getTaskState, Const.GLASS_STATE_DAMAGE_TAKE)); - List<String> glassIdList = outDamageTaskInfoList.stream().map(BigStorageCageOutTask::getGlassId).collect(Collectors.toList()); - //绉婚櫎閽㈠寲涓嬬墖琛ㄦ暟鎹� - temperingGlassInfoService.remove(new LambdaQueryWrapper<TemperingGlassInfo>().in(TemperingGlassInfo::getGlassId, glassIdList)); - //鐞嗙墖绗艰鎯呰〃鏁版嵁鐘舵�佸垹闄� - bigStorageCageDetailsService.remove(new LambdaQueryWrapper<BigStorageCageDetails>().in(BigStorageCageDetails::getGlassId, glassIdList)); - //灏嗙牬鎹熶俊鎭柊澧炲叆鐮存崯琛� - List<Integer> slotList = new ArrayList<>(); - for (BigStorageCageOutTask bigStorageCageOutTask : outDamageTaskInfoList) { - Damage damage = new Damage(); - damage.setGlassId(bigStorageCageOutTask.getGlassId()); - damage.setLine(bigStorageCageOutTask.getEndSlot()); - damage.setWorkingProcedure("閽㈠寲"); - damage.setRemark("鍑虹墖鍚庡崸杞珛"); - damage.setStatus(1); - damage.setType(bigStorageCageOutTask.getTaskState()); - damageService.insertDamage(damage); - slotList.add(bigStorageCageOutTask.getStartSlot()); - } - //鏇存柊鏍煎瓙鍓╀綑瀹藉害 - baseService.updateSlotRemainBySlots(slotList); - log.info("鍑虹墖浠诲姟鎵ц瀹屾垚"); - } - Date endDate = new Date(); - log.info("澶х悊鐗囩鐮存崯鐜荤拑娓呴櫎浠诲姟缁撴潫鏃堕棿锛歿}锛屽叡鑰楁椂锛歿}ms,缁撴潫鎵爜浠诲姟", endDate, endDate.getTime() - startDate.getTime()); - return; - } - - } \ No newline at end of file -- Gitblit v1.8.0