From 1950b0635a0db2c5286f8330e064879e020a7303 Mon Sep 17 00:00:00 2001
From: liurunyu <lry9898@163.com>
Date: 星期五, 22 十一月 2024 14:02:11 +0800
Subject: [PATCH] 1、通信中间件核心模块线程工作由Thread实现改为Timer实现; 2、完善通信中间件远程升级模块及webRemote模块; 3、优化代码。

---
 pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/Server.java |  127 ++++++++++++++++++++++++++++++++----------
 1 files changed, 97 insertions(+), 30 deletions(-)

diff --git a/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/Server.java b/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/Server.java
index d390f5f..1d82e16 100644
--- a/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/Server.java
+++ b/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/Server.java
@@ -9,8 +9,6 @@
 import com.dy.rtuMw.server.tasks.FromRtuComResultConstantTask;
 import com.dy.rtuMw.server.tasks.FromRtuDataConstantTask;
 import com.dy.common.mw.UnitInterface;
-import com.dy.common.mw.channel.rmi.RmiConfigVo;
-import com.dy.common.mw.channel.rmi.RmiUnit;
 import com.dy.common.mw.channel.tcp.TcpConfigVo;
 import com.dy.common.mw.channel.tcp.TcpUnit;
 import com.dy.common.mw.core.CoreUnit;
@@ -19,21 +17,26 @@
 import com.dy.common.mw.protocol.ProtocolUnit;
 import com.dy.common.mw.support.SupportUnit;
 import com.dy.common.mw.support.SupportUnitConfigVo;
-import com.dy.rtuMw.server.tasks.ToRtuConstantTask;
+import com.dy.rtuMw.server.tasks.SendMsConstantTask;
+import com.dy.rtuMw.server.tasks.RtuDownConstantTask;
 import com.dy.rtuMw.resource.ResourceUnit;
 import com.dy.rtuMw.resource.ResourceUnitConfigVo;
 import com.dy.common.springUtil.SpringContextUtil;
-import com.dy.common.util.ConfigXml;
+import com.dy.common.util.ConfigXml4Springboot;
 import com.dy.common.util.IDLongGenerator;
 
+import com.dy.rtuMw.server.upgrade.UpgradeUnit;
+import com.dy.rtuMw.server.upgrade.UpgradeUnitConfigVo;
 import org.jdom2.Document;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.beans.factory.annotation.Value;
+import org.springframework.core.io.ResourceLoader;
 import org.springframework.stereotype.Component;
 
 @Component
 public class Server {
 
-	private ConfigXml conf = null ;
+	private ConfigXml4Springboot conf = null ;
 	private Document doc = null ;
 	private boolean showStartInfo = false ;
 	
@@ -44,6 +47,9 @@
 	@Value("${server.servlet.context-path}")
 	private String HttpSvPath ;
 
+	@Autowired
+	protected ResourceLoader resourceLoader ;
+
 	private List<UnitInterface> units = new ArrayList<UnitInterface>() ;
 
 	/*
@@ -52,27 +58,35 @@
 		new Server().startServer();
 	}
 	*/
+
+	public void  startServer(){
+		/**
+		try {
+			URL url = Server.class.getResource("/config/this.licence");
+			if(!new Lnp(null).parese(url.getPath())){
+				System.out.println("licence error!") ;
+				return ;
+			}
+		} catch (Exception e) {
+			System.out.println("licence error!") ;
+			return ;
+		}
+		*/
+		if(this.doStartServer()){
+			ServerShutDownHook.OnShutDown();
+		}
+	}
 	/**
 	 * 鍚姩鏈嶅姟
  	 */
-	public void startServer(){
-//		try {
-//			URL url = Server.class.getResource("/config/this.licence");
-//			if(!new Lnp(null).parese(url.getPath())){
-//				System.out.println("zhzc licence error!") ;   
-//				return ;
-//			}
-//		} catch (Exception e) {
-//			System.out.println("zhzc licence error!") ; 
-//			return ;
-//		}
-		//Server sv = new Server();
+	private boolean doStartServer(){
+		boolean running = false ;
 		long start = System.currentTimeMillis() ;
 		try {
 			//ConfigProperties.init(this.getClass().getResourceAsStream("/config/config.properties"), false);
 			
-			this.conf = new ConfigXml() ;
-			this.doc = this.conf.createDom(this.getClass(), "config.xml") ;
+			this.conf = new ConfigXml4Springboot() ;
+			this.doc = this.conf.createDom(this.resourceLoader, "config.xml") ;
 			////////////////
 			//鏈嶅姟 閰嶇疆
 			this.showStartInfo = this.conf.getSetAttrBoolean(this.doc, "config.server", "showStartInfo", null, null) ;
@@ -119,21 +133,42 @@
             System.out.println("@@@@@@@@@@@@@@@@@@@@@@#      &@@@@@@@@       Runing in standalone mode" ) ;    
             System.out.println("@@@@@@@@@@@@@@@@@@@@@&       &@@@@@@@@       Startup in " + (System.currentTimeMillis() - start) + " MS" ) ;              
             System.out.println("@@@@@@@@@@@@@@@@@@@#         &@@@@@@@@       " + company) ;            
-            System.out.println("@@@@@@@@@@@@@@@@#O           &@@@@@@@@") ;              
-
+            System.out.println("@@@@@@@@@@@@@@@@#O           &@@@@@@@@") ;
+			running = true ;
 		}catch(Exception e){
 			e.printStackTrace();
+			running = false ;
 		}
+		return running ;
 	}
 	
 	private void startUnits(){
 		try {
 			///////////////
 			//鍩烘湰閰嶇疆
+			ServerProperties.orgTag = this.conf.getSetAttrTxt(this.doc, "config.base", "orgTag", null, false, null) ;
+			if(ServerProperties.orgTag==null || ServerProperties.orgTag.trim().equals("")){
+				throw new Exception("鏈烘瀯tag涓嶈兘涓虹┖") ;
+			}
 			ServerProperties.isLowPower = conf.getSetAttrBoolean(doc, "config.base", "isLowPower", null, null) ; 
 			if(ServerProperties.isLowPower == null){
 				ServerProperties.isLowPower = false ;
 			}
+
+			String onlyDealRtus = conf.getSetAttrTxt(doc, "config.base", "onlyDealRtus", null, true, null) ;
+			if(onlyDealRtus == null || onlyDealRtus.trim().equals("")){
+				ServerProperties.onlyDealRtusTest = false ;
+			}else{
+				onlyDealRtus = onlyDealRtus.replaceAll("锛�", ",") ;
+				onlyDealRtus = onlyDealRtus.replaceAll(" ", "") ;
+				ServerProperties.onlyDealRtus = onlyDealRtus.split(",") ;
+				if(ServerProperties.onlyDealRtus != null && ServerProperties.onlyDealRtus.length > 0){
+					ServerProperties.onlyDealRtusTest = true ;
+				}else{
+					ServerProperties.onlyDealRtusTest = false ;
+				}
+			}
+
 			//鍦ㄦ敮鎸佸閫氫俊鍗忚鏃讹紝鍙湁RTU涓婄嚎浜嗭紝鎵嶈兘璇嗗埆鍑鸿RTU瀹為檯鐢ㄧ殑閫氫俊鍗忚锛岃繘鑰岀敤姝ゅ崗璁В鏋愪笂琛屾暟鎹強鏋勯�犱笅琛屽懡浠ゃ��
 			//濡傛灉RTU鏈浘涓婄嚎锛堥�氫俊涓棿浠跺惎鍔ㄥ悗璇TU鏈浘涓婄嚎锛夛紝閭d箞鍦ㄥ悜瀹冨彂閫佷笅琛屽懡浠ゆ椂锛屼笉鑳藉垽鏂嚭鍏堕噰鐢ㄧ殑鍗忚锛屼篃涓嶈兘鏋勯�犲懡浠わ紝灏ゅ叾鏄綆鍔熻�楁儏鍐典笅锛屼笉涓婄嚎鏄甯哥幇璞°��
 			// 褰撳彧鏈変竴涓崗璁儏鍐典笅锛屽湪RTU鏈浘涓婄嚎鏃讹紝涔熻兘鐢ㄦ鍗忚鏋勯�犲懡浠ゅ苟缂撳瓨涓嬫潵锛屽挨鍏堕�傚悎浣庡姛鑰楁儏鍐点��
@@ -147,7 +182,7 @@
 			//閽堝涓�涓猂TU锛屼笅鍙戝懡浠ょ殑鏃堕棿闂撮殧
 			ServerProperties.commandSendInterval = conf.getSetAttrPlusInt(doc, "config.base", "commandSendInterval", null, 1, 40, null) * 1000L ;
 			//鍛戒护宸茬粡鍙戦�佽揪鏈�澶ф鏁帮紝浠嶆湭鏀跺埌鍛戒护缁撴灉锛岄渶瑕佸湪缂撳瓨缁х画绛夊緟锛屽叾绛夊緟鏈�澶ф椂闀�
-			ServerProperties.cachWaitResultTimeout = conf.getSetAttrPlusInt(doc, "config.base", "cachWaitResultTimeout", null, 10, 60, null) * 1000L ;
+			ServerProperties.cachWaitResultTimeout = conf.getSetAttrPlusInt(doc, "config.base", "cachWaitResultTimeout", null, 10, 360, null) * 1000L ;
 			//涓嶅湪绾跨紦瀛樼殑鍛戒护鏈�澶х紦瀛樻椂闀�
 			ServerProperties.offLineCachTimeout = conf.getSetAttrPlusInt(doc, "config.base", "offLineCachTimeout", null, 15, 172800, null) * 1000L ;
 			//TCP涓婅鏁版嵁鏃跺埢缂撳瓨鏃堕暱锛屽綋杈惧埌鏃堕暱鏃讹紝TCP涓婅鏁版嵁鏃跺埢琚竻绌猴紝閲囩敤TCP涓婅鏁版嵁鏃跺埢鐩殑鏄紝闃绘涓婃暟鎹悓鏃朵笅鍙戞暟鎹紝鍥犱负RTU澶勭悊涓嶈繃鏉�
@@ -161,12 +196,21 @@
 			if(ServerProperties.cacheUpDownDataMaxCount <= ServerProperties.cacheUpDownDataWarnCount){
 				throw new Exception("cacheUpDownDataMaxCount蹇呴』澶т簬cacheUpDownDataWarnCount") ;
 			}
-			//娌℃湁涓婅鏁版嵁鐨勫垎閽熸暟锛岃揪鍒拌繖涓垎閽熸暟锛岃涓篟TU鏂綉浜嗭紝鍙栧�艰寖鍥存槸2_100
+			//娌℃湁涓婅鏁版嵁鐨勫垎閽熸暟锛岃揪鍒拌繖涓垎閽熸暟锛岃涓篟TU鏂綉浜嗭紝鍙栧�艰寖鍥存槸2-100
 			ServerProperties.disconnectedByNoUpDataMinutes =  0L + conf.getSetAttrPlusInt(doc, "config.base", "disconnectedByNoUpDataMinutes", null, 1, 100, null) ;
 			if(ServerProperties.disconnectedByNoUpDataMinutes < 1 || ServerProperties.disconnectedByNoUpDataMinutes > 100){
 				throw new Exception("disconnectedByNoUpDataMinutes鍙栧�煎繀椤绘槸1~100") ;
 			}
 			ServerProperties.disconnectedByNoUpDataMinutes = ServerProperties.disconnectedByNoUpDataMinutes * 60 * 1000 ;
+
+			//宸ヤ綔鎶ュお棰戠箒锛孨娆′笂鎶ュ鐞�1娆★紝鍙栧�艰寖鍥存槸1-100
+			ServerProperties.workReportDealOneByTimes =  conf.getSetAttrPlusInt(doc, "config.base", "workReportDealOneByTimes", null, 1, 100, null) ;
+
+			//瑙﹀彂鍙戦�侀拤閽夋姤璀︽秷鎭殑鍙栨按鍙f棩婕忔崯閲忕殑鏈�灏忓�硷紙鍖呮嫭浣嗛櫎0.0澶栵級
+			ServerProperties.intakeAlarmLossMinValue =  conf.getSetAttrPlusDouble(doc, "config.base", "intakeAlarmLossMinValue", null, 0.0, 1000000.0, null) ;
+
+			//鏈夋姤璀﹀彂鐢熸椂锛屽悜閽夐拤鍙戦�佹秷鎭殑闂撮殧鏃堕暱锛堝垎閽燂級
+			ServerProperties.sendDingDingAlarmMsInterval =  conf.getSetAttrPlusInt(doc, "config.base", "sendDingDingAlarmMsInterval", null, 1, 600, null) ;
 
 			//璁剧疆ID鐢熸垚鍣ㄧ殑鍚庣紑
 			IDLongGenerator.setSuffix(ServerProperties.dbDataIdSuffix.intValue());
@@ -245,7 +289,7 @@
 			//RTU鏃ュ織鏂囦欢瀛樺偍鐩綍(鐩稿鐩綍)
 			resVo.rtuLogDir = conf.getSetAttrTxt(doc, "config.resource", "rtuLogDir", null, false, null) ;
 			//RTU鏃ュ織鏂囦欢鏈�澶у瓧鑺傛暟(KB)
-			resVo.rtuLogFileMaxSize = conf.getSetAttrPlusInt(doc, "config.resource", "rtuLogFileMaxSize", null, 100000, 2000000, null) ;
+			resVo.rtuLogFileMaxSize = conf.getSetAttrPlusInt(doc, "config.resource", "rtuLogFileMaxSize", null, 10, 2000000, null) ;
 			//RTU鏃ュ織鏂囦欢鏈�澶ф枃浠舵暟
 			resVo.rtuLogFileMaxCount = conf.getSetAttrPlusInt(doc, "config.resource", "rtuLogFileMaxCount", null, 1, 10, null) ; 
 			
@@ -269,7 +313,8 @@
 
 			
 			/////////////////
-			//RMI妯″潡
+			//RMI妯″潡 鏆傛椂涓嶅簲鐢�
+			/*
 			RmiConfigVo rmiVo = new RmiConfigVo();
 			rmiVo.enable = conf.getSetAttrBoolean(doc, "config.rmi", "enable", null, null) ;
 			if(rmiVo.enable){
@@ -285,11 +330,33 @@
 				RmiSvUrl = "[ip]:" + rmiVo.port + "/" + rmiVo.context ;
 				units.add(rmiUnit) ;
 			}
-
+			*/
 
 			/////////////////
-			//RTU涓婅鏁版嵁澶勭悊妯″潡
+			//RTU杩滅▼鍗囩骇妯″潡
+			UpgradeUnitConfigVo ugVo = new UpgradeUnitConfigVo();
+			ugVo.enable = conf.getSetAttrBoolean(doc, "config.upgrade", "enable", null, null) ;
+			ugVo.noOneRtuUpgradeMaxDuration = conf.getSetAttrPlusInt(doc, "config.upgrade", "noOneRtuUpgradeMaxDuration", null, 5, 3600, null);
+			ugVo.noOneRtuUpgradeMaxDuration = ugVo.noOneRtuUpgradeMaxDuration * 1000 ;//鍙樻垚姣
+			ugVo.failTryTimes = conf.getSetAttrPlusInt(doc, "config.upgrade", "failTryTimes", null, 0, 100, null);
+			ugVo.ugMaxRtuAtOnce = conf.getSetAttrPlusInt(doc, "config.upgrade", "ugMaxRtuAtOnce", null, 0, 1000000, null);
+			ugVo.rtuOffLineWaitDuration = conf.getSetAttrPlusInt(doc, "config.upgrade", "rtuOffLineWaitDuration", null, 1, 36000, null);
+			ugVo.rtuOffLineWaitDuration = ugVo.rtuOffLineWaitDuration * 1000;//鍙樻垚姣
+			ugVo.notifyStateInterval = conf.getSetAttrPlusInt(doc, "config.upgrade", "notifyStateInterval", null, 1, 300, null);
+			ugVo.notifyStateInterval = ugVo.notifyStateInterval * 1000;//鍙樻垚姣
+			ugVo.showStartInfo = showStartInfo ;
+			AdapterImp_UpgradeUnit ugAdap = new AdapterImp_UpgradeUnit();
+			ugAdap.setConfig(ugVo);
+			UpgradeUnit ugUnit = UpgradeUnit.getInstance();
+			ugUnit.setAdapter(ugAdap);
+			ugUnit.start(obj -> {
+			});
+			units.add(ugUnit) ;
+
+			/////////////////
+			//RTU涓婅鏁版嵁澶勭悊妯″潡锛堜换鍔℃爲锛�
 			RtuDataUnitConfigVo rducVo = new RtuDataUnitConfigVo();
+			rducVo.resourceLoader = this.resourceLoader ;
 			AdapterImp_RtuDataUnit rducAdap = new AdapterImp_RtuDataUnit();
 			rducAdap.setConfig(rducVo);
 			RtuDataUnit rducUnit = RtuDataUnit.getInstance();
@@ -303,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 ;
@@ -312,9 +378,10 @@
 			coreAdap.setConfig(coreConfVo);
 			CoreUnit coreUnit = CoreUnit.getInstance();
 			coreUnit.setAdapter(coreAdap);
-			CoreUnit.addConstantTask(new ToRtuConstantTask());
+			CoreUnit.addConstantTask(new RtuDownConstantTask());
 			CoreUnit.addConstantTask(new FromRtuDataConstantTask());
 			CoreUnit.addConstantTask(new FromRtuComResultConstantTask());
+			CoreUnit.addConstantTask(new SendMsConstantTask());
 			coreUnit.start(obj -> {
 			});
 			units.add(coreUnit) ;

--
Gitblit v1.8.0