pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/core/CoreConstantManage.java
@@ -1,5 +1,6 @@ package com.dy.common.mw.core; import java.util.ArrayList; import java.util.List; import org.apache.logging.log4j.*; @@ -10,10 +11,12 @@ private final static CoreConstantManage instance = new CoreConstantManage() ; private static Long sleepBigBusy = 100L ;//å¤§å¿æ¶ï¼é¤äºæä¹ ä»»å¡ï¼è¿æ¯å ¶ä»ä»»å¡ï¼ï¼æ ¸å¿çº¿ç¨æåé´é private static Long sleepSmallBusy = 500L ;//å°å¿æ¶ï¼åªææä¹ ä»»å¡ï¼æ å ¶ä»ä»»å¡ï¼ï¼æ ¸å¿çº¿ç¨æåé´é private List<CoreConstantTimer> coreConstantTimers ; private Long coreInterval = 100L ;//æ ¸å¿çº¿ç¨æåé´é private CoreConstantManage(){ coreConstantTimers = new ArrayList<>() ; } public static CoreConstantManage getInstance(){ @@ -22,12 +25,10 @@ /** * 设置æåæ¶é¿ * @param sleepBigBusy å¤§å¿æ¶ï¼é¤äºæä¹ ä»»å¡ï¼è¿æ¯å ¶ä»ä»»å¡ï¼ï¼æ ¸å¿çº¿ç¨æåé´é * @param sleepSmallBusy å°å¿æ¶ï¼åªææä¹ ä»»å¡ï¼æ å ¶ä»ä»»å¡ï¼ï¼æ ¸å¿çº¿ç¨æåé´é * @param coreInterval æ ¸å¿çº¿ç¨æåé´é */ public void setSleep(Long sleepBigBusy, Long sleepSmallBusy){ CoreConstantManage.sleepBigBusy = sleepBigBusy ; CoreConstantManage.sleepSmallBusy = sleepSmallBusy ; public void setSleep(Long coreInterval){ this.coreInterval = coreInterval ; } public void start(){ @@ -35,7 +36,8 @@ List<CoreTask> constantTasks = CoreUnit.getAllConstantTasks(); if (constantTasks != null && constantTasks.size() > 0) { for (CoreTask task : constantTasks) { new CoreConstantThread(sleepBigBusy, sleepSmallBusy, task).start(); //new CoreConstantThread(sleepBigBusy, sleepSmallBusy, task).start(); coreConstantTimers.add(new CoreConstantTimer(coreInterval, task).start()); } } } pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/core/CoreConstantThread.java
@@ -9,6 +9,15 @@ * @LastEditTime 2023/12/19 16:41 * @Description */ /** * 2024-11-21 该类已ç»å¼ç¨ï¼æ¹ç±CoreConstantTimerå®ç°ã * å½éç¨Threadå®ç°æ¶ï¼å¨while(true){}ä¸ä½¿ç¨Thread.sleep()ï¼å¯è½å¯¼è´ç䏥鿧è½é®é¢ï¼ä¸æ¨èå¨å¾ªç¯ä¸ä½¿ç¨çº¿ç¨ä¼ç ã * Java线ç¨å®ç°éç¨å æ ¸çº¿ç¨å®ç°ï¼çº¿ç¨çä¼ç åå¤éï¼ç¶æåæ¢ï¼éå婿ä½ç³»ç»è¿è¡ï¼è¿æ¯ä¸ä¸ªæå ¶èæ¶èåçæä½ã * å¨çº¿ç¨ä¼ç æè¿è¡æ¶é´è¾é¿çæ æ¯ä¸ï¼å ¶å¯¹æ§è½çå½±åè¿ä¸ç®ææ¾ï¼å 为对线ç¨ç¶æç忢并ä¸é¢ç¹ã * ä½è¥çº¿ç¨ä¼ç åè¿è¡çæ¶é´é½å¾çï¼ä¾å¦æ¯«ç§/ç§ï¼ï¼ * ç³»ç»å°é¢ç¹ç对线ç¨ç¶æè¿è¡åæ¢ï¼å¯¼è´ä¸¥éçæ§è½æèï¼å¹¶å¯¹çå¾ªç¯æ¬¡æ°çéå¢èæ¾å¤§ã */ @Deprecated public class CoreConstantThread extends Thread { private final static Logger log = LogManager.getLogger(CoreConstantThread.class.getName()) ; pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/core/CoreConstantTimer.java
New file @@ -0,0 +1,45 @@ package com.dy.common.mw.core; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import java.util.Timer; import java.util.TimerTask; /** * @Author: liurunyu * @Date: 2024/11/21 17:13 * @Description */ public class CoreConstantTimer extends TimerTask { private final static Logger log = LogManager.getLogger(CoreConstantTimer.class.getName()) ; private Timer timer; private long coreInterval ; private CoreTask task ; public CoreConstantTimer(long coreInterval, CoreTask task){ this.timer = new Timer(); this.coreInterval = coreInterval ; this.task = task ; } public CoreConstantTimer start(){ this.timer.schedule(this, 0 , this.coreInterval); return this ; } @Override public void run() { if(task != null){ try { task.execute(); } catch (Exception e) { log.error("æä¹ ä»»å¡" + task.getClass().getName() + "æ§è¡æ¶åçå¼å¸¸" + (e.getMessage() == null ? "" : (":" + e.getMessage())), e); } } } } pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/core/CoreThread.java
@@ -4,6 +4,15 @@ import com.dy.common.queue.Queue; /** * 2024-11-21 该类已ç»å¼ç¨ï¼æ¹ç±CoreTimerå®ç°ã * å½éç¨Threadå®ç°æ¶ï¼å¨while(true){}ä¸ä½¿ç¨Thread.sleep()ï¼å¯è½å¯¼è´ç䏥鿧è½é®é¢ï¼ä¸æ¨èå¨å¾ªç¯ä¸ä½¿ç¨çº¿ç¨ä¼ç ã * Java线ç¨å®ç°éç¨å æ ¸çº¿ç¨å®ç°ï¼çº¿ç¨çä¼ç åå¤éï¼ç¶æåæ¢ï¼éå婿ä½ç³»ç»è¿è¡ï¼è¿æ¯ä¸ä¸ªæå ¶èæ¶èåçæä½ã * å¨çº¿ç¨ä¼ç æè¿è¡æ¶é´è¾é¿çæ æ¯ä¸ï¼å ¶å¯¹æ§è½çå½±åè¿ä¸ç®ææ¾ï¼å 为对线ç¨ç¶æç忢并ä¸é¢ç¹ã * ä½è¥çº¿ç¨ä¼ç åè¿è¡çæ¶é´é½å¾çï¼ä¾å¦æ¯«ç§/ç§ï¼ï¼ * ç³»ç»å°é¢ç¹ç对线ç¨ç¶æè¿è¡åæ¢ï¼å¯¼è´ä¸¥éçæ§è½æèï¼å¹¶å¯¹çå¾ªç¯æ¬¡æ°çéå¢èæ¾å¤§ã */ @Deprecated public class CoreThread extends Thread{ private static Logger log = LogManager.getLogger(CoreThread.class.getName()) ; pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/core/CoreTimer.java
New file @@ -0,0 +1,80 @@ package com.dy.common.mw.core; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import java.util.Timer; import java.util.TimerTask; /** * @Author: liurunyu * @Date: 2024/11/21 13:41 * @Description */ public class CoreTimer extends TimerTask { private static final Logger log = LogManager.getLogger(CoreTimer.class.getName()) ; private static final CoreTimer instance = new CoreTimer() ; private Long workInterval = 100L ;//æ ¸å¿çº¿ç¨æåé´é private Timer timer; private boolean stop; private CoreTimer(){ this.timer = new Timer(); this.stop = false ; } public static CoreTimer getInstance(){ return instance ; } public void stop(){ this.stop = true ; if(this.timer != null){ this.timer.cancel(); } } public boolean isStop(){ return this.stop ; } /** * 设置/æ ¸å¿çº¿ç¨æåé´é * @param workInterval /æ ¸å¿çº¿ç¨æåé´é */ public void setSleep(Long workInterval){ this.workInterval = workInterval ; } public void start(){ this.timer.schedule(this, 0 , this.workInterval); } /** * TimerTaskçrunæ¹æ³ */ @Override public void run() { try{ /** * æ¤å¤ååºå½åéåçèç¹æ°éï¼ä½ä¸ºä¸ä¸ªå®écountå¤çï¼ * åå : * å¨å¤çå®écountè¿ç¨ä¸ï¼å¯è½æçèç¹ååå°éåä¸ï¼ä¹å¯è½æ°çèç¹è¿å ¥éåä¸ï¼å³å¨å¤çè¿ç¨ä¸ï¼éåå¯è½åå¢é¿äº */ int count = CoreUnit.taskQueue.size() ; while(count > 0){ CoreTask task = (CoreTask)CoreUnit.taskQueue.pop() ; if(task != null){ task.execute(); } count-- ; } }catch(Exception e){ log.error("æ ¸å¿çº¿ç¨åçå¼å¸¸" + (e.getMessage() == null ? "" : (":" + e.getMessage())), e);; } } } pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/core/CoreUnit.java
@@ -8,6 +8,7 @@ import com.dy.common.mw.UnitInterface; import com.dy.common.mw.UnitCallbackInterface; public class CoreUnit implements UnitInterface { private static final CoreUnit instance = new CoreUnit() ; @@ -36,17 +37,14 @@ if(vo == null){ throw new Exception("æ ¸å¿æ¨¡åé 置对象ä¸è½ä¸ºç©ºï¼") ; } if(vo.sleepBigBusy == null || vo.sleepSmallBusy == null){ if(vo.coreInterval == null){ throw new Exception("æ ¸å¿æ¨¡åé 置对象é´é屿§å¼ä¸è½ä¸ºç©ºï¼") ; } if(vo.sleepBigBusy <= 0){ throw new Exception("æ ¸å¿æ¨¡åé ç½®å¯¹è±¡å±æ§sleepBigBusyå¼ä¸è½å°äº0ï¼") ; if(vo.coreInterval <= 0){ throw new Exception("æ ¸å¿æ¨¡åé ç½®å¯¹è±¡å±æ§coreIntervalå¼ä¸è½å°äº0ï¼") ; } if(vo.sleepBigBusy > 1000){ throw new Exception("æ ¸å¿æ¨¡åé ç½®å¯¹è±¡å±æ§sleepBigBusyå¼ä¸è½å¤§äº1000ï¼") ; } if(vo.sleepSmallBusy > 1000){ throw new Exception("æ ¸å¿æ¨¡åé ç½®å¯¹è±¡å±æ§sleepSmallBusyå¼ä¸è½å¤§äº1000ï¼") ; if(vo.coreInterval > 1000){ throw new Exception("æ ¸å¿æ¨¡åé ç½®å¯¹è±¡å±æ§coreIntervalå¼ä¸è½å¤§äº1000ï¼") ; } if(vo.queueWarnSize == null || vo.queueMaxSize == null){ throw new Exception("æ ¸å¿æ¨¡åé 置对象éåèç¹éå¶æ°é屿§å¼ä¸è½ä¸ºç©ºï¼") ; @@ -67,18 +65,22 @@ public void start(UnitCallbackInterface callback) throws Exception { if(!started){ started = true ; /* CoreThread ct = CoreThread.getInstance() ; ct.setSleep(this.adapter.getConfig().sleepBigBusy, this.adapter.getConfig().sleepSmallBusy); ct.start(); ct.start(); */ CoreTimer ct = CoreTimer.getInstance() ; ct.setSleep(this.adapter.getConfig().coreInterval); ct.start(); CoreConstantManage ccm = CoreConstantManage.getInstance() ; ccm.setSleep(this.adapter.getConfig().sleepBigBusy, this.adapter.getConfig().sleepSmallBusy); ccm.setSleep(this.adapter.getConfig().coreInterval); ccm.start(); if(adapter.getConfig().showStartInfo){ System.out.println("æ ¸å¿æ¨¡åæåå¯å¨ï¼" + "主线ç¨ç¹å¿é´éï¼" + adapter.getConfig().sleepBigBusy + "毫ç§ï¼" + "è½»é²é´éï¼" + adapter.getConfig().sleepSmallBusy + "毫ç§" ); + "ä¸»çº¿ç¨æ§è¡é´éï¼" + adapter.getConfig().coreInterval + "毫ç§"); } callback.call(null); } pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/core/CoreUnitConfigVo.java
@@ -1,8 +1,7 @@ package com.dy.common.mw.core; public class CoreUnitConfigVo { public Long sleepBigBusy = 100L ;//å¤§å¿æ¶ï¼é¤äºæä¹ ä»»å¡ï¼è¿æå ¶ä»ä»»å¡éå¤çï¼ï¼æ ¸å¿çº¿ç¨æåé´é public Long sleepSmallBusy = 500L ;//å°å¿æ¶ï¼åªææä¹ ä»»å¡ï¼æ å ¶ä»ä»»å¡éå¤çï¼ï¼æ ¸å¿çº¿ç¨æåé´é public Long coreInterval = 100L ;//å¤§å¿æ¶ï¼é¤äºæä¹ ä»»å¡ï¼è¿æå ¶ä»ä»»å¡éå¤çï¼ï¼æ ¸å¿çº¿ç¨æåé´é public Integer queueWarnSize = 1000 ;//é忥è¦é¿åº¦ public Integer queueMaxSize = 5000 ;//éåæå¤§é¿åº¦ public Boolean showStartInfo; //æ¯å¦å¨æ§å¶å°ä¸æ¾ç¤ºä¿¡æ¯ pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/util/ThreadJob.java
@@ -2,6 +2,7 @@ @SuppressWarnings("unused") @Deprecated public abstract class ThreadJob { protected Thread thread ; protected boolean stop = false ; pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/util/TimerTaskJob.java
@@ -7,11 +7,12 @@ * @Author: liurunyu * @Date: 2024/11/20 17:49 * @Description : * 2024-11-20ï¼ * æ¤æ½è±¡ç±»ä»£æ¿ThreadJobï¼åå ï¼ * å¨while(true){}ä¸ä½¿ç¨Thread.sleep()ï¼å¯è½å¯¼è´ç䏥鿧è½é®é¢ï¼ä¸æ¨èå¨å¾ªç¯ä¸ä½¿ç¨çº¿ç¨ä¼ç ã * Java线ç¨å®ç°éç¨å æ ¸çº¿ç¨å®ç°ï¼çº¿ç¨çä¼ç åå¤éï¼ç¶æåæ¢ï¼éå婿ä½ç³»ç»è¿è¡ï¼è¿æ¯ä¸ä¸ªæå ¶èæ¶èåçæä½ã * å¨çº¿ç¨ä¼ç æè¿è¡æ¶é´è¾é¿çæ æ¯ä¸ï¼å ¶å¯¹æ§è½çå½±åè¿ä¸ç®ææ¾ï¼å 为对线ç¨ç¶æç忢并ä¸é¢ç¹ã * ä½è¥çº¿ç¨ä¼ç åè¿è¡çæ¶é´é½å¾çï¼ä¾å¦æ¯«ç§/ç§ï¼æä¸æ¡ä¾å°±æ¯ä¸ä¸ªå ¸åæ¡ä¾ï¼ï¼ * ä½è¥çº¿ç¨ä¼ç åè¿è¡çæ¶é´é½å¾çï¼ä¾å¦æ¯«ç§/ç§ï¼ï¼ * ç³»ç»å°é¢ç¹ç对线ç¨ç¶æè¿è¡åæ¢ï¼å¯¼è´ä¸¥éçæ§è½æèï¼å¹¶å¯¹çå¾ªç¯æ¬¡æ°çéå¢èæ¾å¤§ã */ public abstract class TimerTaskJob { pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/voUg/VoUgRtuResult.java
New file @@ -0,0 +1,30 @@ package com.dy.pipIrrGlobal.voUg; import com.alibaba.excel.annotation.ExcelProperty; import com.alibaba.excel.annotation.write.style.ColumnWidth; import com.alibaba.excel.annotation.write.style.ContentRowHeight; import com.alibaba.excel.annotation.write.style.ContentStyle; import com.alibaba.excel.annotation.write.style.HeadRowHeight; import com.alibaba.excel.enums.poi.HorizontalAlignmentEnum; import com.alibaba.excel.enums.poi.VerticalAlignmentEnum; import lombok.Data; /** * @Author: liurunyu * @Date: 2024/11/22 14:26 * @Description */ @Data @HeadRowHeight(26) @ContentRowHeight(22) public class VoUgRtuResult { @ExcelProperty("æ§å¶å¨å°å") @ColumnWidth(20) @ContentStyle(horizontalAlignment = HorizontalAlignmentEnum.CENTER, verticalAlignment = VerticalAlignmentEnum.CENTER) public String rtuAddr; @ExcelProperty("åçº§ç»æ") @ColumnWidth(30) @ContentStyle(horizontalAlignment = HorizontalAlignmentEnum.LEFT, verticalAlignment = VerticalAlignmentEnum.CENTER) public String result; } pipIrr-platform/pipIrr-global/src/main/resources/application-global.yml
@@ -313,7 +313,7 @@ #å½ä»¤åéå°å(ä¸ç¼æ¯æºætagï¼å ¶ä¹æ¯æ°æ®æºåç¼åç§°) ym: comSendUrl: "http://127.0.0.1:8070/rtuMw/com/send" ugTaskSendUrl: "http://192.168.40.132:8070/rtuMw/com/upgradeRtu" ugTaskSendUrl: "http://127.0.0.1:8070/rtuMw/com/upgradeRtu" rtuLogFileUrl: "http://127.0.0.1:8070/rtuMw/com/rtuLogFile" rtuLogTextUrl: "http://127.0.0.1:8070/rtuMw/com/rtuLogText" sp: pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/Server.java
@@ -370,8 +370,7 @@ // /////////////// // æ ¸å¿ CoreUnitConfigVo coreConfVo = new CoreUnitConfigVo(); coreConfVo.sleepBigBusy = conf.getSetAttrPlusInt(doc, "config.core", "sleepBigBusy", null, 1, 200, null).longValue() ; coreConfVo.sleepSmallBusy = conf.getSetAttrPlusInt(doc, "config.core", "sleepSmallBusy", null, 2, 1000, null).longValue(); coreConfVo.coreInterval = conf.getSetAttrPlusInt(doc, "config.core", "coreInterval", null, 1, 200, null).longValue() ; coreConfVo.queueWarnSize = ServerProperties.cacheUpDownDataWarnCount ; coreConfVo.queueMaxSize = ServerProperties.cacheUpDownDataMaxCount ; coreConfVo.showStartInfo = showStartInfo ; pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/upgrade/UpgradeTask.java
@@ -13,6 +13,7 @@ import java.util.*; import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.atomic.AtomicBoolean; /** * @Author: liurunyu @@ -202,6 +203,7 @@ if(this.taskVo.rtuAddrList != null && this.taskVo.rtuAddrList.size() > 0){ state.rtuTotal = this.taskVo.rtuAddrList.size() ; if(this.upgradeRtus != null && this.upgradeRtus.size() > 0){ AtomicBoolean hasRunning = new AtomicBoolean(false); this.upgradeRtus.values().stream().forEach(info ->{ if(info.state == UpgradeRtu.STATE_OFFLINE){ state.offLineTotal ++ ; @@ -222,8 +224,15 @@ } if(info.isOver){ state.overTotal++; }else{ hasRunning.set(true); } }); if(!hasRunning.get()){ state.allOver = true ; }else{ state.allOver = false ; } } } return state ; pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/resources/config(spɳÅÌ).xml
@@ -124,14 +124,12 @@ /> <!-- sleepBigBusyï¼ä¸»çº¿ç¨å¤§å¿æ¶æ¯æ¬¡æ§è¡é´éæ¶é¿ï¼æ¯«ç§ï¼ sleepSmallBusyï¼ä¸»çº¿ç¨å°å¿æ¶æ¯æ¬¡æ§è¡é´éæ¶é¿ï¼æ¯«ç§ï¼ coreIntervalï¼ä¸»çº¿ç¨æ¯æ¬¡æ§è¡é´éæ¶é¿ï¼æ¯«ç§ï¼ queueWarnSize: ç¼åéåèç¹æ°è¦åæ°é queueMaxSize: ç¼åéåèç¹æ°æå¤§æ°é --> <core sleepBigBusy="100" sleepSmallBusy="500" coreInterval="100" queueWarnSize="100000" queueMaxSize="300000" /> pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/resources/config(test²âÊÔ).xml
@@ -124,14 +124,12 @@ /> <!-- sleepBigBusyï¼ä¸»çº¿ç¨å¤§å¿æ¶æ¯æ¬¡æ§è¡é´éæ¶é¿ï¼æ¯«ç§ï¼ sleepSmallBusyï¼ä¸»çº¿ç¨å°å¿æ¶æ¯æ¬¡æ§è¡é´éæ¶é¿ï¼æ¯«ç§ï¼ coreIntervalï¼ä¸»çº¿ç¨æ¯æ¬¡æ§è¡é´éæ¶é¿ï¼æ¯«ç§ï¼ queueWarnSize: ç¼åéåèç¹æ°è¦åæ°é queueMaxSize: ç¼åéåèç¹æ°æå¤§æ°é --> <core sleepBigBusy="100" sleepSmallBusy="500" coreInterval="100" queueWarnSize="100000" queueMaxSize="300000" /> pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/resources/config(ymԪı).xml
@@ -124,14 +124,12 @@ /> <!-- sleepBigBusyï¼ä¸»çº¿ç¨å¤§å¿æ¶æ¯æ¬¡æ§è¡é´éæ¶é¿ï¼æ¯«ç§ï¼ sleepSmallBusyï¼ä¸»çº¿ç¨å°å¿æ¶æ¯æ¬¡æ§è¡é´éæ¶é¿ï¼æ¯«ç§ï¼ coreIntervalï¼ä¸»çº¿ç¨æ¯æ¬¡æ§è¡é´éæ¶é¿ï¼æ¯«ç§ï¼ queueWarnSize: ç¼åéåèç¹æ°è¦åæ°é queueMaxSize: ç¼åéåèç¹æ°æå¤§æ°é --> <core sleepBigBusy="100" sleepSmallBusy="500" coreInterval="100" queueWarnSize="100000" queueMaxSize="300000" /> pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/resources/config.xml
@@ -124,14 +124,12 @@ /> <!-- sleepBigBusyï¼ä¸»çº¿ç¨å¤§å¿æ¶æ¯æ¬¡æ§è¡é´éæ¶é¿ï¼æ¯«ç§ï¼ sleepSmallBusyï¼ä¸»çº¿ç¨å°å¿æ¶æ¯æ¬¡æ§è¡é´éæ¶é¿ï¼æ¯«ç§ï¼ coreIntervalï¼ä¸»çº¿ç¨æ¯æ¬¡æ§è¡é´éæ¶é¿ï¼æ¯«ç§ï¼ queueWarnSize: ç¼åéåèç¹æ°è¦åæ°é queueMaxSize: ç¼åéåèç¹æ°æå¤§æ°é --> <core sleepBigBusy="100" sleepSmallBusy="500" coreInterval="100" queueWarnSize="100000" queueMaxSize="300000" /> pipIrr-platform/pipIrr-web/pipIrr-web-remote/src/main/java/com/dy/pipIrrRemote/common/CommandSv.java
@@ -132,7 +132,7 @@ jsonArray.add(jsonObject); }); } System.out.println(jsonArray); //System.out.println(jsonArray); } /** pipIrr-platform/pipIrr-web/pipIrr-web-remote/src/main/java/com/dy/pipIrrRemote/rtuUpgrage/RtuUpgradeCtrl.java
@@ -1,7 +1,8 @@ package com.dy.pipIrrRemote.rtuUpgrage; import com.alibaba.excel.EasyExcel; import com.alibaba.excel.support.ExcelTypeEnum; import com.dy.common.aop.SsoAop; import com.dy.common.multiDataSource.DataSourceContext; import com.dy.common.softUpgrade.state.UpgradeRtu; import com.dy.common.softUpgrade.state.UpgradeTaskVo; import com.dy.common.springUtil.SpringContextUtil; @@ -12,6 +13,8 @@ import com.dy.pipIrrGlobal.pojoUg.UgRtuProgram; import com.dy.pipIrrGlobal.pojoUg.UgRtuTask; import com.dy.pipIrrGlobal.rtuMw.ToRtuMwCom; import com.dy.pipIrrGlobal.voPr.VoDivide; import com.dy.pipIrrGlobal.voUg.VoUgRtuResult; import com.dy.pipIrrGlobal.voUg.VoWatch; import io.swagger.v3.oas.annotations.Operation; import io.swagger.v3.oas.annotations.media.Content; @@ -19,15 +22,19 @@ import io.swagger.v3.oas.annotations.responses.ApiResponse; import io.swagger.v3.oas.annotations.responses.ApiResponses; import io.swagger.v3.oas.annotations.tags.Tag; import jakarta.servlet.http.HttpServletResponse; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.core.env.Environment; import org.springframework.http.MediaType; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.RestController; import org.springframework.web.client.RestTemplate; import java.io.UnsupportedEncodingException; import java.net.URLEncoder; import java.util.ArrayList; import java.util.Base64; import java.util.List; @@ -44,6 +51,9 @@ public class RtuUpgradeCtrl extends ToRtuMwCom { @Autowired private RtuUpgradeSv sv ; @Autowired RtuUpgradeResSv resSv ; @Autowired private Environment env; @@ -128,9 +138,10 @@ vo.softBytesCalculate = ppo.programCalculateBytes ; vo.softByteSrc16 = ppo.programCrc16 ; } /** * çè§ï¼ * éç½®ï¼æ¼ç¤ºçéç½® * éç½®è¿ç¨å级æ¼ç¤ºç¨åº * @return æä½ç»æ */ @GetMapping(path = "/demoReset") @@ -166,7 +177,7 @@ if(qvo == null){ qvo = new QueryVo(); qvo.pageCurr = 1 ; qvo.pageSize = 50 ; qvo.pageSize = 49 ; } if(RtuUpgradeStateReceiverCtrl.cache == null){ //return BaseResponseUtils.buildError("å½å没æå级任å¡") ; @@ -174,96 +185,50 @@ RtuUpgradeStateReceiverCtrl ctrl = SpringContextUtil.getBean(RtuUpgradeStateReceiverCtrl.class); ctrl.demo(); } QueryResultVo<VoWatch> rsVo = new QueryResultVo(); VoWatch vo = new VoWatch() ; List<UpgradeRtu> listFiltered = null ; if(RtuUpgradeStateReceiverCtrl.cache != null && RtuUpgradeStateReceiverCtrl.cache.ugTaskId != null){ vo.upgrade = this.sv.selectTaskDetail(RtuUpgradeStateReceiverCtrl.cache.ugTaskId); vo.overall = RtuUpgradeStateReceiverCtrl.cache.ugOverallState ; vo.rtus = new ArrayList<>() ; if(RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList != null && RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList.size() > 0) { listFiltered = filterByQuery(qvo) ; if (listFiltered.size() > 0) { if(qvo.pageCurr < 1){ qvo.pageCurr = 1 ; } int start = (qvo.pageCurr - 1) * qvo.pageSize ; if(start >= listFiltered.size()){ if(listFiltered.size()%qvo.pageSize > 0){ start = listFiltered.size() - listFiltered.size()%qvo.pageSize ; }else{ start = listFiltered.size() - qvo.pageSize ; } } for(int i = start; i < (start + qvo.pageSize) && i < listFiltered.size(); i++){ UpgradeRtu ugRtu = listFiltered.get(i) ; VoWatch.VoWatchRtu rtu = new VoWatch.VoWatchRtu() ; rtu.fromCache(ugRtu) ; vo.rtus.add(rtu) ; } } } } rsVo.obj = vo ; rsVo.pageSize = qvo.pageSize ; rsVo.pageCurr = qvo.pageCurr ; rsVo.calculateAndSet(0L + (listFiltered==null?0:listFiltered.size()), null); QueryResultVo<VoWatch> rsVo = this.resSv.curUpgradeState(qvo) ; return BaseResponseUtils.buildSuccess(rsVo) ; } private List<UpgradeRtu> filterByQuery(QueryVo qvo){ if (qvo.status != null || qvo.result != null) { final Integer qvoStatus = qvo.status ; final Integer qvoResult = qvo.result ; final String qvoRtuAddr = qvo.rtuAddr ; return RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList.stream().filter(rtu -> { boolean ok = false; if (qvoStatus != null) { if (qvoStatus.intValue() == 1) { if (rtu.state == UpgradeRtu.STATE_RUNNING) { ok = true; }else{ ok = false ; } } else if (qvoStatus.intValue() == 0) { if (rtu.isOver) { ok = true; }else{ ok = false ; } } } if (qvoResult != null) { if (qvoResult.intValue() == 1) { if (rtu.state == UpgradeRtu.STATE_SUCCESS) { ok = true; }else{ ok = false ; } } else if (qvoResult.intValue() == 0) { if (rtu.state == UpgradeRtu.STATE_OFFLINE || rtu.state == UpgradeRtu.STATE_FAILONE || rtu.state == UpgradeRtu.STATE_FAIL || rtu.state == UpgradeRtu.STATE_FAILOFFLINE) { ok = true; }else{ ok = false ; } } } if(qvoRtuAddr != null && !qvoRtuAddr.trim().equals("")){ if(rtu.rtuAddr.equals(qvoRtuAddr)){ ok = true; }else{ ok = false ; } } return ok; }).toList() ; }else{ return RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList ; } /** * 导åºå级失败RTUå表 * @param response */ @RequestMapping(value = "/exportUgFail", method = RequestMethod.GET) public void exportUgFail(HttpServletResponse response) throws Exception { setExcelRespProp(response, "å级失败RTUå表"); List<VoUgRtuResult> rsList = resSv.exportUgFail(); EasyExcel.write(response.getOutputStream()) .head(VoUgRtuResult.class) .excelType(ExcelTypeEnum.XLSX) .sheet("å级失败RTUå表") .doWrite(rsList); } /** * 导åºé¿çº§æåRTUå表 * @param response */ @RequestMapping(value = "/exportUgSuccess", method = RequestMethod.GET) public void exportUgSuccess(HttpServletResponse response) throws Exception { setExcelRespProp(response, "å级æåRTUå表"); List<VoUgRtuResult> rsList = resSv.exportUgSuccess(); EasyExcel.write(response.getOutputStream()) .head(VoUgRtuResult.class) .excelType(ExcelTypeEnum.XLSX) .sheet("å级æåRTUå表") .doWrite(rsList); } /** * 设置excelä¸è½½ååºå¤´å±æ§ */ private void setExcelRespProp(HttpServletResponse response, String rawFileName) throws UnsupportedEncodingException { response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"); response.setCharacterEncoding("utf-8"); String fileName = URLEncoder.encode(rawFileName, "UTF-8").replaceAll("\\+", "%20"); response.setHeader("Content-disposition", "attachment;filename*=utf-8''" + fileName + ".xlsx"); } } pipIrr-platform/pipIrr-web/pipIrr-web-remote/src/main/java/com/dy/pipIrrRemote/rtuUpgrage/RtuUpgradeResSv.java
New file @@ -0,0 +1,160 @@ package com.dy.pipIrrRemote.rtuUpgrage; import com.dy.common.softUpgrade.state.UpgradeRtu; import com.dy.common.webUtil.QueryResultVo; import com.dy.pipIrrGlobal.voUg.VoUgRtuResult; import com.dy.pipIrrGlobal.voUg.VoWatch; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import java.util.ArrayList; import java.util.List; /** * @Author liurunyu * @Date 2024/11/22 14:40 * @Description */ @Slf4j @Service public class RtuUpgradeResSv { @Autowired private RtuUpgradeSv sv ; public QueryResultVo<VoWatch> curUpgradeState(QueryVo qvo){ QueryResultVo<VoWatch> rsVo = new QueryResultVo<>(); VoWatch vo = new VoWatch() ; List<UpgradeRtu> listFiltered = null ; if(RtuUpgradeStateReceiverCtrl.cache != null && RtuUpgradeStateReceiverCtrl.cache.ugTaskId != null){ vo.upgrade = this.sv.selectTaskDetail(RtuUpgradeStateReceiverCtrl.cache.ugTaskId); vo.overall = RtuUpgradeStateReceiverCtrl.cache.ugOverallState ; vo.rtus = new ArrayList<>() ; if(RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList != null && RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList.size() > 0) { listFiltered = filterByQuery(qvo) ; if (listFiltered.size() > 0) { if(qvo.pageCurr < 1){ qvo.pageCurr = 1 ; } int start = (qvo.pageCurr - 1) * qvo.pageSize ; if(start >= listFiltered.size()){ if(listFiltered.size()%qvo.pageSize > 0){ start = listFiltered.size() - listFiltered.size()%qvo.pageSize ; }else{ start = listFiltered.size() - qvo.pageSize ; } } for(int i = start; i < (start + qvo.pageSize) && i < listFiltered.size(); i++){ UpgradeRtu ugRtu = listFiltered.get(i) ; VoWatch.VoWatchRtu rtu = new VoWatch.VoWatchRtu() ; rtu.fromCache(ugRtu) ; vo.rtus.add(rtu) ; } } } } rsVo.obj = vo ; rsVo.pageSize = qvo.pageSize ; rsVo.pageCurr = qvo.pageCurr ; rsVo.calculateAndSet((long)(listFiltered==null?0:listFiltered.size()), null); return rsVo ; } /** * è¿æ»¤ç»æ * @param qvo æ¥è¯¢åæ° * @return éå */ private List<UpgradeRtu> filterByQuery(QueryVo qvo){ if (qvo.status != null || qvo.result != null) { Integer qvoStatus = qvo.status ; Integer qvoResult = qvo.result ; String qvoRtuAddr = qvo.rtuAddr ; return RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList.stream().filter(rtu -> { boolean ok = false; if (qvoStatus != null) { if (qvoStatus == 1) { ok = rtu.state == UpgradeRtu.STATE_RUNNING; } else if (qvoStatus == 0) { ok = rtu.isOver; } } if (qvoResult != null) { if (qvoResult == 1) { ok = rtu.state == UpgradeRtu.STATE_SUCCESS; } else if (qvoResult == 0) { ok = rtu.state == UpgradeRtu.STATE_OFFLINE || rtu.state == UpgradeRtu.STATE_FAILONE || rtu.state == UpgradeRtu.STATE_FAIL || rtu.state == UpgradeRtu.STATE_FAILOFFLINE; } } if(qvoRtuAddr != null && !qvoRtuAddr.trim().equals("")){ ok = rtu.rtuAddr.equals(qvoRtuAddr); } return ok; }).toList() ; }else{ return RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList ; } } /** * è¿æ»¤åºå½åé¿çº§ä»»å¡ä¸å级失败çRTU * @return éå */ public List<VoUgRtuResult> exportUgFail(){ List<VoUgRtuResult> list = new ArrayList<>() ; if(RtuUpgradeStateReceiverCtrl.cache != null && RtuUpgradeStateReceiverCtrl.cache.ugTaskId != null){ if(RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList != null && RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList.size() > 0) { RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList.forEach(rtu -> { if(rtu.isOver){ if(rtu.state == UpgradeRtu.STATE_OFFLINE || rtu.state == UpgradeRtu.STATE_UNSTART || rtu.state == UpgradeRtu.STATE_FAILOFFLINE){ VoUgRtuResult vo = new VoUgRtuResult() ; vo.rtuAddr = rtu.rtuAddr ; vo.result = "离线" ; list.add(vo); }else if(rtu.state == UpgradeRtu.STATE_FAILONE){ VoUgRtuResult vo = new VoUgRtuResult() ; vo.rtuAddr = rtu.rtuAddr ; vo.result = "ä¸å æ»" ; list.add(vo); }else if(rtu.state == UpgradeRtu.STATE_FAIL){ VoUgRtuResult vo = new VoUgRtuResult() ; vo.rtuAddr = rtu.rtuAddr ; vo.result = "å¤å æ»" ; list.add(vo); } } }); } } return list ; } /** * è¿æ»¤åºå½åé¿çº§ä»»å¡ä¸å级æåçRTU * @return éå */ public List<VoUgRtuResult> exportUgSuccess(){ List<VoUgRtuResult> list = new ArrayList<>() ; if(RtuUpgradeStateReceiverCtrl.cache != null && RtuUpgradeStateReceiverCtrl.cache.ugTaskId != null){ if(RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList != null && RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList.size() > 0) { RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList.forEach(rtu -> { if(rtu.isOver){ if(rtu.state == UpgradeRtu.STATE_SUCCESS){ VoUgRtuResult vo = new VoUgRtuResult() ; vo.rtuAddr = rtu.rtuAddr ; vo.result = "å级æå" ; list.add(vo); } } }); } } return list ; } } pipIrr-platform/pipIrr-web/pipIrr-web-remote/src/main/java/com/dy/pipIrrRemote/rtuUpgrage/RtuUpgradeStateReceiverCtrl.java
@@ -244,7 +244,7 @@ } int n = Integer.parseInt(new CreateRandom().create(3)) ; if(n == 540 || n == 541 || n == 542 || n == 543 || n == 544 || n == 545){ if(n == 540 || n == 541 || n == 542 || n == 543 || n == 544 || n == 545 || n == 546 || n == 547 || n == 548 || n == 549 ){ if(rtu.currentPackage == 1){ //1å æ» rtu.state = UpgradeRtu.STATE_FAILONE ; pipIrr-platform/pipIrr-web/pipIrr-web-remote/src/main/java/com/dy/pipIrrRemote/rtuUpgrage/RtuUpgradeSv.java
@@ -58,28 +58,6 @@ } /** * æ¥è¯¢ä¸ä¸ªåçº§ä»»å¡æå ³ä¿¡æ¯ * @return åçº§ä»»å¡æå ³ä¿¡æ¯ */ public VoUpgradeDetail selectTaskDetail(String taskId){ List<VoUpgradeDetail> list = this.tdao.selectTaskDetail(Long.valueOf(taskId)) ; if(list != null && list.size() > 0){ return list.get(0) ; } return null ; } /** * ä¿åå级任å¡ä¸ºæ§è¡ç¶æ * @param taskId ä»»å¡ID */ public void setUpgradeTaskExecuted(String taskId){ this.tdao.executeById(Long.valueOf(taskId)) ; } /** * ä¿åRTUåçº§ç»æç¶æ * @param taskId * @param rtu @@ -91,17 +69,38 @@ cdao.updateRtuUpgradeState(params) ; } ///////////////////////////////////////////////////// // // 以䏿¨¡ææ°æ® // ///////////////////////////////////////////////////// /** * éä¿¡ä¸»é®æ¥è¯¢ä¸ä¸ªåçº§ä»»å¡ * æ¥è¯¢ä¸ä¸ªåçº§ä»»å¡æå ³ä¿¡æ¯ * @return åçº§ä»»å¡æå ³ä¿¡æ¯ */ public VoUpgradeDetail selectTaskDetail(String taskId){ List<VoUpgradeDetail> list = this.tdao.selectTaskDetail(Long.valueOf(taskId)) ; if(list != null && list.size() > 0){ return list.get(0) ; } return null ; } /** * ä¿åå级任å¡ä¸ºæ§è¡ç¶æ * @param taskId ä»»å¡ID */ public void setUpgradeTaskExecuted(String taskId){ this.tdao.executeById(Long.valueOf(taskId)) ; } ///////////////////////////////////////////////////// // // 以䏿¼ç¤ºå级åè½ç¨å° // ///////////////////////////////////////////////////// /** * æ¥è¯¢ææ°ä¸ä¸ªåçº§ä»»å¡ * @return */ public UgRtuTask selectLastTask(){ return tdao.selectLastTask(); } } pipIrr-platform/pom.xml
@@ -271,11 +271,11 @@ <scope>import</scope> </dependency> <!-- quartz --> <!-- rocketmq-client --> <dependency> <groupId>org.apache.rocketmq</groupId> <artifactId>rocketmq-client</artifactId> <version>4.9.7</version> <version>5.3.1</version> <type>pom</type> <scope>import</scope> </dependency>