From 8d725e7bd1ad30b5ba437cbf420da622cfefc7c6 Mon Sep 17 00:00:00 2001
From: wuzeyu <1223318623@qq.com>
Date: 星期五, 22 十一月 2024 15:52:44 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/upgrade/UpgradeManager.java |  242 ++++++++++++++++++++++++++++++++++++------------
 1 files changed, 181 insertions(+), 61 deletions(-)

diff --git a/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/upgrade/UpgradeManager.java b/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/upgrade/UpgradeManager.java
index aff5c1b..af7d7fa 100644
--- a/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/upgrade/UpgradeManager.java
+++ b/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/upgrade/UpgradeManager.java
@@ -1,15 +1,27 @@
 package com.dy.rtuMw.server.upgrade;
 
+import com.dy.common.softUpgrade.state.UpgradeInfo;
+import com.dy.common.softUpgrade.state.UpgradeRtu;
+import com.dy.common.softUpgrade.state.UpgradeState;
+import com.dy.common.softUpgrade.state.UpgradeTaskVo;
+import com.dy.common.springUtil.SpringContextUtil;
 import com.dy.common.util.Callback;
-
+import com.dy.common.util.DateTime;
+import com.dy.common.util.TimerTaskJob;
+import com.dy.rtuMw.web.webRequest.WebRequestDeal;
+import org.apache.logging.log4j.LogManager;
+import org.apache.logging.log4j.Logger;
 import java.util.List;
 
 /**
- * @Author: liurunyu
- * @Date: 2024/11/4 16:03
+ *  鍗囩骇绠$悊绫�
+ * @Author liurunyu
+ * @Date 2024/11/4 16:03
  * @Description
  */
-public class UpgradeManager {
+public class UpgradeManager extends TimerTaskJob implements Callback {
+
+    private static final Logger log = LogManager.getLogger(UpgradeManager.class.getName());
 
     private static final UpgradeManager INSTANCE = new UpgradeManager();
 
@@ -17,11 +29,11 @@
     private Integer ugMaxRtuSameTime ;//鍚屾椂鍗囩骇RTU鏈�澶т釜鏁�
 
     private UpgradeTask task ;//鍗囩骇浠诲姟
+    private boolean monitorFirst = true ;//鏄惁鏄涓�娆$洃瑙�
 
-    private boolean taskIsOver = false ;//鍗囩骇浠诲姟鏄惁缁撴潫
-    private int triggerTimes = 0 ;//杩炴帴瑙﹀彂娆℃暟
-
-    private UpgradeManager(){}
+    private UpgradeManager(){
+        monitorFirst = true ;
+    }
 
     public static UpgradeManager getInstance() {
         return UpgradeManager.INSTANCE;
@@ -32,46 +44,48 @@
      */
     public void initOption(UpgradeUnitConfigVo configVo) {
         this.failTryTimes = configVo.failTryTimes;
-        this.ugMaxRtuSameTime = configVo.ugMaxRtuSameTime;
+        this.ugMaxRtuSameTime = configVo.ugMaxRtuAtOnce;
     }
 
     /**
      * 璁剧疆鍗囩骇浠诲姟
-     * @param softFileName 鍗囩骇绋嬪簭鏂囦欢鍚�
-     * @param softStoreAddr 鍗囩骇绋嬪簭瀛樻斁鍦板潃
-     * @param softStartAddr 绋嬪簭瑕嗙洊璧峰鍦板潃
-     * @param softFileData 鍗囩骇绋嬪簭瀛楄妭鏁扮粍
-     * @param softBytesCalculate 鍗囩骇绋嬪簭瀛楄妭鏁�(鎸夊叕寮忚绠�)
-     * @param rtuAddrList 鍗囩骇RTU
-     * @throws Exception
+     * @param vo UpgradeTaskVo 鍗囩骇浠诲姟瀵硅薄
+     * @throws Exception 寮傚父
      */
-    public void setUpgradeTask(String softFileName,
-                               String softStoreAddr,
-                               String softStartAddr,
-                               byte[] softFileData,
-                               Integer softBytesCalculate,
-                               List<String> rtuAddrList) throws Exception {
-        if(this.task != null && !this.task.isOver()){
-            throw new Exception("褰撳墠瀛樺湪鍗囩骇浠诲姟锛岃绛夊緟褰撳墠浠诲姟鎵ц瀹屾垨寮哄埗鍋滄褰撳墠浠诲姟");
-        }else{
-            this.task.forceOver();
-            this.task = new UpgradeTask();
-            this.task.initOption(this.failTryTimes, this.ugMaxRtuSameTime);
-            this.task.setTask(softFileName,
-                    softStoreAddr,
-                    softStartAddr,
-                    softFileData,
-                    softBytesCalculate,
-                    rtuAddrList);
+    public void setUpgradeTask(UpgradeTaskVo vo) throws Exception {
+        if(this.task != null && !this.task.taskIsOver){
+            throw new Exception("褰撳墠瀛樺湪鍗囩骇浠诲姟锛岃绛夊緟褰撳墠浠诲姟鎵ц瀹屾垨寮哄埗缁撴潫褰撳墠浠诲姟");
+        }else {
+            Exception ex = null ;
+            try{
+                if(this.task != null){
+                    this.task.forceOver();
+                }
+                this.task = new UpgradeTask();
+                this.task.initOption(this.failTryTimes, this.ugMaxRtuSameTime);
+                this.task.setTask(vo);
+            }catch (Exception e){
+                ex = e ;
+            }finally {
+                if(ex != null){
+                    this.task = null ;
+                    throw ex ;
+                }else{
+                    this.start(1000L, (long) UpgradeUnit.confVo.notifyStateInterval, this);
+                }
+            }
         }
     }
 
     /**
-     * 鍋滄褰撳墠鍗囩骇浠诲姟
-     * @throws Exception
+     * 寮哄埗缁撴潫褰撳墠鍗囩骇浠诲姟锛�
+     * 姝ゅ姛鑳藉彲鑳戒笉浼氬紑鏀惧嚭鍘伙紝
+     * 鍥犱负寮哄埗缁撴潫鍗囩骇浠诲姟锛屽涓�涓湭鍗囩骇瀹屾垚鐨凴TU灏变細鍗℃锛�
+     * 鎵�浠ュ綋寮哄埗缁撴潫鍗囩骇浠诲姟锛屼唬鐮侀�昏緫骞舵病鏈夊己鍒剁粨鏋淩TU鍗囩骇杩囩▼锛屽鏋滃崌绾ц繃绋嬩篃寮哄埗鍋滄锛岄偅涔圧TU鐪熶細鍗℃
      */
-    public void stopUpgradeTask() throws Exception {
+    public void forceOverUpgradeTask() {
         if(this.task != null){
+            this.stop();
             this.task.forceOver();
         }
         this.task = null ;
@@ -79,24 +93,15 @@
 
     /**
      * RTU鏈変笂琛屾暟鎹簡锛岃Е鍙戜笅鍙戝崌绾ф暟鎹�
-     * @param rtuAddr
-     * @param code
-     * @param protocolName
-     * @param protocolVersion
-     * @param callback
+     * @param rtuAddr 鎺у埗鍣≧TU鍦板潃
+     * @param code 涓婅鏁版嵁鍔熻兘鐮�
+     * @param protocolName 涓婅鏁版嵁瀵瑰簲鐨勫崗璁悕绉�
+     * @param protocolVersion 涓婅鏁版嵁瀵瑰簲鐨勫崗璁増鏈彿
+     * @param callbackCom 鍥炶皟鍑芥暟锛屽鐞嗕笅琛屽懡浠�
      */
-    public void trigger(String rtuAddr, String code, String protocolName, Short protocolVersion, Callback callback){
-        if(task != null && !taskIsOver){
-            triggerTimes ++ ;
-            if(triggerTimes == 100){
-                triggerTimes = 0 ;
-                if(this.task.isOver()){
-                    taskIsOver = true ;
-                }
-            }
-            if(!taskIsOver){
-                this.task.trigger(rtuAddr, code, protocolName, protocolVersion, callback);
-            }
+    public void trigger(String rtuAddr, String code, String protocolName, Short protocolVersion, Callback callbackCom){
+        if(task != null && !task.taskIsOver){
+            this.task.trigger(rtuAddr, code, protocolName, protocolVersion, callbackCom);
         }
     }
 
@@ -107,7 +112,7 @@
     ////////////////////////////////////////////////////
     /**
      * 褰撳墠鍗囩骇鐘舵��
-     * @return
+     * @return 褰撳墠鍗囩骇鐘舵��
      */
     public UpgradeState currentUpgradeState() {
         if(task != null){
@@ -119,10 +124,11 @@
 
     /**
      * Rtu鍗囩骇淇℃伅
-     * @param rtuAddr
-     * @return
+     * @param rtuAddr 鎺у埗鍣≧TU鍦板潃
+     * @return 鎺у埗鍣≧TU鍗囩骇鐘舵��
      */
-    public UpgradeRtu upgradeInfos(String rtuAddr){
+    @SuppressWarnings("unused")
+    public UpgradeRtu upgradeRtuInfo(String rtuAddr){
         if(task != null){
             return task.upgradeInfos(rtuAddr) ;
         }else{
@@ -132,10 +138,11 @@
 
     /**
      * Rtu鍗囩骇淇℃伅
-     * @param rtuAddrList
-     * @return
+     * @param rtuAddrList 鎺у埗鍣ㄥ湴鍧�鍒楄〃
+     * @return 鎸囧畾鍒楄〃涓殑鎺у埗鍣≧TU鍗囩骇鐘舵��
      */
-    public List<UpgradeRtu> upgradeInfos(List<String> rtuAddrList){
+    @SuppressWarnings("unused")
+    public List<UpgradeRtu> upgradeRtuInfos(List<String> rtuAddrList){
         if(task != null){
             return task.upgradeInfos(rtuAddrList) ;
         }else{
@@ -144,4 +151,117 @@
     }
 
 
+    /**
+     * 鎵�鏈塕tu鍗囩骇淇℃伅
+     * @return 鎵�鏈塕tu鍗囩骇淇℃伅
+     */
+    public List<UpgradeRtu> upgradeRtuInfoAll(){
+        if(task != null){
+            return task.upgradeInfoAll() ;
+        }else{
+            return null ;
+        }
+    }
+
+
+    ////////////////////////////////////////////////////
+    //
+    // 鍗囩骇鏈嶅姟宸ヤ綔绾跨▼鎵ц鐨勬柟娉�
+    // 缁熻鐘舵�� + 鐘舵�侀�氱煡
+    //
+    ////////////////////////////////////////////////////
+    public Object execute() {
+        if(this.task == null
+                || this.task.taskVo == null
+                || this.task.taskVo.rtuAddrList == null
+                || this.task.taskVo.rtuAddrList.size() == 0){
+            //浠诲姟涓虹┖
+            this.stop() ;
+        }else{
+            if(!this.task.taskIsOver){
+                //鍗囩骇浠诲姟鏈畬鎴�
+                //宸ヤ綔1锛氬垽鏂槸鍚︽棤浠讳綍涓�涓猂TU杩涜杩囧崌绾э紝骞朵笖杈惧埌鏃堕檺锛屽垯璁や负褰撳墠鍗囩骇浠诲姟瀹屾垚
+                //-1:鏃犱竴RTU鍗囩骇涓旇秴鏃讹紝0锛氭棤RTU鍗囩骇浣嗘湭瓒呮椂绛夊緟锛�1鏈塕TU鍗囩骇姝e父鎵ц
+                int temp = this.task.countNoOneRtuUpgradeInDuration() ;
+                if(temp == -1){
+                    this.task.taskIsOver = true ;
+                    //浠诲姟宸茬粡瀹屾垚
+                    this.stop();
+                }else if(temp == 1){
+                    //宸ヤ綔2锛氱粺璁″綋鍓嶆鍦ㄥ崌绾х殑RTU鏁伴噺锛屼负鍚屾椂鍗囩骇鏁伴噺闄愬埗鍋氬噯澶�
+                    this.task.countRunningRtuCount() ;
+
+                    //宸ヤ綔3锛氱粺璁¢渶瑕佸崌绾т絾褰撳墠绂荤嚎RTU鐨勬儏鍐碉紝瓒呰繃鏃堕檺鐨勮澶囦负鍗囩骇瀹屾垚
+                    this.task.countOffRtuAndSetIfOver() ;
+
+                    //宸ヤ綔4锛氱粺璁℃槸鍚﹀叏閮ㄥ崌绾у畬鎴�
+                    this.task.taskIsOver = this.task.countIsAllOver() ;
+                }else if(temp == 0){
+                    //涓嶄綔涓�
+                }
+                if(this.task.taskIsOver){
+                    if(!this.task.taskOverType.equals(UpgradeTask.TaskOverType_Force)){
+                        //浠诲姟涓嶆槸寮哄埗缁撴潫鐨�
+                        this.task.taskOverType = UpgradeTask.TaskOverType_Natural ;//浠诲姟瀹屾垚鏂瑰紡锛堣嚜鐒讹紝寮哄埗锛�
+                        this.task.taskOverDt = DateTime.yyyy_MM_dd_HH_mm_ss() ;//浠诲姟瀹屾垚鏃堕棿(yyyy-mm-dd HH:MM:SS)
+                    }
+                    //浠诲姟瀹屾垚锛屾墽琛屾渶鍚庝竴娆″崌绾х姸鎬侀�氱煡
+                    //宸ヤ綔5锛氬崌绾х姸鎬侀�氱煡
+                    //if(!first){
+                    //    this.notifyUpgradeStatus() ;
+                    //}
+                }else{
+                    //浠诲姟鏈畬鎴愶紝缁х画鎵ц鍗囩骇鐘舵�侀�氱煡
+                    //宸ヤ綔5锛� 鍗囩骇鐘舵�侀�氱煡
+                    //if(!first){
+                    //    this.notifyUpgradeStatus() ;
+                    //}
+                }
+                //宸ヤ綔5锛氬崌绾х姸鎬侀�氱煡
+                if(!this.monitorFirst){
+                    this.notifyUpgradeStatus() ;
+                }
+            }else{
+                //浠诲姟宸茬粡瀹屾垚
+                this.stop();
+            }
+        }
+        if(this.monitorFirst){
+            this.monitorFirst = false ;
+        }
+        return true ;
+    }
+
+    /**
+     * 鍗囩骇鐘舵�侀�氱煡
+     */
+    private void notifyUpgradeStatus(){
+        if(this.task.taskVo.callbackWebUrl != null && this.task.taskVo.callbackWebUrl.length() > 0){
+            UpgradeInfo info = new UpgradeInfo() ;
+            info.ugTaskId = this.task.taskVo.id ;//浠诲姟ID
+            info.ugOverallState = this.currentUpgradeState() ;
+            info.ugRtuStateList = this.upgradeRtuInfoAll() ;
+            WebRequestDeal deal = SpringContextUtil.getBean(WebRequestDeal.class) ;
+            deal.deal(this.task.taskVo.callbackWebUrl, info);
+        }
+    }
+
+    ////////////////////////////////////////////////////
+    //
+    // 鍗囩骇鐘舵�侀�氱煡宸ヤ綔绾跨▼鎵ц瀹屾垚鍚庡洖璋冪殑鏂规硶锛�
+    // 涔熷氨鏄笂闈xecute鏂规硶鎵ц瀹屾垚杩斿洖鎴栨姏鍑哄紓甯稿悗锛屾墽琛屼笅闈笁涓柟娉�
+    //
+    ////////////////////////////////////////////////////
+    @Override
+    public void call(Object obj) {
+        //绾跨▼宸ヤ綔鎵ц瀹屼簡锛宱bj = Boolean(true)
+    }
+    @Override
+    public void call(Object... objs) {
+    }
+    @Override
+    public void exception(Exception e) {
+        log.error("杩滅▼鍗囩骇浼烘湇绾跨▼鍙戠敓寮傚父", e);
+    }
+
 }

--
Gitblit v1.8.0