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-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/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 ;