From 9483baffba9a24a2a36fc8739fc65b59317d9142 Mon Sep 17 00:00:00 2001 From: zhang <zc857179121@qq.com> Date: 星期四, 03 七月 2025 14:18:46 +0800 Subject: [PATCH] 队列拆分 --- zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/AgvDataService.java | 141 ++++++---------------------------------------- 1 files changed, 19 insertions(+), 122 deletions(-) diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/AgvDataService.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/AgvDataService.java index f3c07bb..c9d1c32 100644 --- a/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/AgvDataService.java +++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/AgvDataService.java @@ -2,13 +2,14 @@ import com.alibaba.fastjson.JSON; import com.zy.acs.common.domain.AgvProtocol; -import com.zy.acs.common.domain.protocol.*; -import com.zy.acs.common.enums.AgvStatusType; +import com.zy.acs.common.domain.protocol.AGV_12_UP; +import com.zy.acs.common.domain.protocol.IMessageBody; import com.zy.acs.common.utils.GsonUtils; import com.zy.acs.common.utils.RedisSupport; import com.zy.acs.framework.common.Cools; +import com.zy.acs.framework.common.DateUtils; +import com.zy.acs.manager.core.constant.MapDataConstant; import com.zy.acs.manager.core.domain.BackpackDto; -import com.zy.acs.manager.manager.entity.Agv; import com.zy.acs.manager.manager.entity.AgvDetail; import com.zy.acs.manager.manager.entity.Code; import com.zy.acs.manager.manager.service.*; @@ -60,15 +61,15 @@ IMessageBody msgBody = protocol.getMessageBody(); assert msgBody != null; - Agv agv = agvService.selectByUuid(protocol.getAgvNo()); - if (null == agv) { + Long agvId = agvService.getAgvId(protocol.getAgvNo()); + if (null == agvId) { log.warn("Agv [{}] 灏氭湭閴存潈 锛侊紒锛�", protocol.getAgvNo()); return; } - AgvDetail detail = agvDetailService.selectByAgvId(agv.getId()); + AgvDetail detail = agvDetailService.selectByAgvId(agvId); if (null == detail) { detail = new AgvDetail(); - detail.setAgvId(agv.getId()); + detail.setAgvId(agvId); if (!agvDetailService.save(detail)) { log.error("Agv [{}] 璇︽儏鏇存柊澶辫触 锛侊紒锛�", protocol.getAgvNo()); return; @@ -81,11 +82,12 @@ AGV_12_UP agv_12_up = (AGV_12_UP) msgBody; // unlock path - threadPoolRegulator.getInstance().execute(() -> { - mapService.unlockPath(protocol.getAgvNo(), agv_12_up.getQrCode()); - }); + mapService.unlockPath(protocol.getAgvNo(), agv_12_up.getQrCode()); +// threadPoolRegulator.getInstance().execute(() -> { +// +// }); // finish jam - threadPoolRegulator.getInstance().execute(() -> jamService.checkIfFinish(agv.getId(), agv_12_up.getQrCode())); + threadPoolRegulator.getInstance().execute(() -> jamService.checkIfFinish(agvId, agv_12_up.getQrCode())); // websocketService.agvInfoBroadcastOnPos(new WebsocketDto<AGV_12_UP>("agv", agv.getUuid(), agv_12_up)); this.sync(agv_12_up, detail); @@ -94,35 +96,12 @@ log.info("Agv [{}] 鏈夌爜瀹炴椂鏁版嵁鍖� ===>> {}", protocol.getAgvNo(), JSON.toJSONString(agv_12_up)); } } - // 鏃犵爜瀹炴椂鏁版嵁鍖� - if (msgBody instanceof AGV_13_UP) { - AGV_13_UP agv_13_up = (AGV_13_UP) msgBody; -// websocketService.agvInfoBroadcastWithOutPos(new WebsocketDto<AGV_13_UP>("agv", agv.getUuid(), agv_13_up)); - this.sync(agv_13_up, detail); -// redis.setObject(RedisConstant.DIGITAL_AGV_FLAG, agv.getUuid(), agv_13_up); - if (PRINT_LOG) { - log.info("Agv [{}] 鏃犵爜瀹炴椂鏁版嵁鍖� ===>> {}", protocol.getAgvNo(), JSON.toJSONString(agv_13_up)); + // 鏁呴殰澶嶄綅 + if (!Cools.isEmpty(detail.realError())) { + assert detail.getErrorTime() != null; + if (DateUtils.diffToSeconds(detail.getErrorTime(), new Date()) > 20) { + detail.setError(MapDataConstant.EMPTY_OF_ERROR); } - } - // 蹇冭烦鍖� - if (msgBody instanceof AGV_03_UP) { - AGV_03_UP agv_03_up = (AGV_03_UP) msgBody; - this.sync(agv_03_up, detail); - if (PRINT_LOG) { - log.info("Agv [{}] 蹇冭烦鍖� ===>> {}", protocol.getAgvNo(), JSON.toJSONString(agv_03_up)); - } - } - // 鐧婚檰鍖� - if (msgBody instanceof AGV_F0_UP) { - AGV_F0_UP agv_f0_up = (AGV_F0_UP) msgBody; - this.sync(agv_f0_up, detail); - log.info("Agv [{}] 鐧婚檰鍖� ===>> {}", protocol.getAgvNo(), JSON.toJSONString(agv_f0_up)); - } - // 鏁呴殰鏁版嵁鍖� - if (msgBody instanceof AGV_04_UP) { - AGV_04_UP agv_04_up = (AGV_04_UP) msgBody; - log.info("Agv [{}] 鏁呴殰鏁版嵁鍖� ===>> {}", protocol.getAgvNo(), JSON.toJSONString(agv_04_up)); -// faultProcessor.execute(new VehicleFaultDto()); } if (!agvDetailService.updateById(detail)) { @@ -135,7 +114,7 @@ private void sync(AGV_12_UP mesBody, AgvDetail detail) { detail.setStatus(mesBody.getStatus()); - Code code = codeService.selectByData(mesBody.getQrCode()); + Code code = codeService.getCacheByData(mesBody.getQrCode()); if (null != code) { detail.setCode(code.getId()); detail.setLastCode(null); @@ -179,87 +158,5 @@ } - // 鏃犵爜瀹炴椂鏁版嵁鍖� - private void sync(AGV_13_UP mesBody, AgvDetail detail) { - detail.setStatus(mesBody.getStatus()); - - Code code = codeService.selectByData(mesBody.getQrCode()); - if (null != code) { - - if (!detail.getAgvStatus().equals(AgvStatusType.CHARGE)) { - detail.setCode(null); - detail.setLastCode(code.getId()); - detail.setPos(0); - } else { - detail.setCode(code.getId()); - detail.setLastCode(null); - detail.setPos(1); - } - - - } else { - log.error("Agv [{}] 鏇存柊瀹氫綅鏁版嵁澶辫触 锛侊紒锛佷笂浼犳潯鐮侊細{}", agvService.getById(detail.getAgvId()).getUuid(), mesBody.getQrCode()); - } - - detail.setStraightVal((double) mesBody.getStraightDirectionPosition()); - - detail.setAgvAngle((double) mesBody.getAGVCurrentAngle()); - - detail.setGyroAngle((double) mesBody.getGyroAngle()); - - detail.setEncoderAngle((double) mesBody.getEncoderAngle()); - - detail.setHigh(mesBody.getCurrentAltitude()); - - detail.setSensorSts((long) mesBody.getSensorStatusFlags()); - - List<BackpackDto> backpackDtoList = new ArrayList<>(); - backpackDtoList.add(new BackpackDto(1, mesBody.isTempLoc1())); - backpackDtoList.add(new BackpackDto(2, mesBody.isTempLoc2())); - backpackDtoList.add(new BackpackDto(3, mesBody.isTempLoc3())); - backpackDtoList.add(new BackpackDto(4, mesBody.isTempLoc4())); - backpackDtoList.add(new BackpackDto(5, mesBody.isTempLoc5())); - backpackDtoList.add(new BackpackDto(6, mesBody.isTempLoc6())); - backpackDtoList.add(new BackpackDto(7, mesBody.isTempLoc7())); - detail.setBackpack(GsonUtils.toJson(backpackDtoList)); - - } - - // 蹇冭烦鍖� - private void sync(AGV_03_UP mesBody, AgvDetail detail) { - - detail.setVol(mesBody.getVoltage()); - detail.setSoc(mesBody.getSoc()); - detail.setSoh(mesBody.getSoh()); - detail.setBatteryFail(mesBody.getBatterFailSign()); - - detail.setTempe(JSON.toJSONString(Cools - .add("batteryTempe", mesBody.getBatteryTempe()) - .add("envirTempe", mesBody.getEnvirTempe()) - .add("leftMotorTempe", mesBody.getLeftMotorTempe()) - .add("rightMotorTempe", mesBody.getRightMotorTempe()) - .add("raiseMotorTempe", mesBody.getRaiseMotorTempe()) - .add("telescopicMotorTempe", mesBody.getTelescopicMotorTempe()) - .add("rotatingMotorTempe", mesBody.getRotatingMotorTempe()) - )); - - detail.setMotorFail(JSON.toJSONString(Cools - .add("leftMotorFailSign", mesBody.getLeftMotorFailSign()) - .add("rightMotorFailSign", mesBody.getRightMotorFailSign()) - .add("raiseMotorFailSign", mesBody.getRaiseMotorFailSign()) - .add("telescopicMotorFailSign", mesBody.getTelescopicMotorFailSign()) - .add("rotatingMotorFailSign", mesBody.getRotatingMotorFailSign()) - )); - - detail.setFailSign(String.valueOf(mesBody.getFailSign())); - - detail.setBootTime(mesBody.getBootTime()); - - } - - // 鐧婚檰鍖� - private void sync(AGV_F0_UP mesBody, AgvDetail detail) { - - } } -- Gitblit v1.9.1