package com.dy.aceMw; 
 | 
  
 | 
import java.util.ArrayList; 
 | 
import java.util.List; 
 | 
  
 | 
import com.dy.aceMw.server.tasks.BusiConstantTask; 
 | 
import com.dy.common.mw.UnitInterface; 
 | 
import com.dy.common.mw.UnitStartedCallbackInterface; 
 | 
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; 
 | 
import com.dy.common.mw.core.CoreUnitConfigVo; 
 | 
import com.dy.common.mw.protocol.ProtocolConfigVo; 
 | 
import com.dy.common.mw.protocol.ProtocolUnit; 
 | 
import com.dy.common.mw.support.SupportUnit; 
 | 
import com.dy.common.mw.support.SupportUnitConfigVo; 
 | 
import com.dy.aceMw.server.AdapterImp_CoreUnit; 
 | 
import com.dy.aceMw.server.AdapterImp_ProtocolUnit; 
 | 
import com.dy.aceMw.server.AdapterImp_RmiUnit; 
 | 
import com.dy.aceMw.server.AdapterImp_TcpUnit; 
 | 
import com.dy.aceMw.server.ServerProperties; 
 | 
import com.dy.aceMw.server.tasks.ToRtuConstantTask; 
 | 
import com.dy.aceMw.server.AdapterImp_SupportUnit; 
 | 
import com.dy.aceMw.resource.ResourceUnit; 
 | 
import com.dy.aceMw.resource.ResourceUnitConfigVo; 
 | 
import com.dy.aceMw.server.AdapterImp_ResourceUnit; 
 | 
import com.dy.common.springUtil.SpringContextUtil; 
 | 
import com.dy.common.util.ConfigXml; 
 | 
import com.dy.common.util.IDLongGenerator; 
 | 
  
 | 
import org.jdom2.Document; 
 | 
import org.springframework.stereotype.Component; 
 | 
  
 | 
@Component 
 | 
public class Server { 
 | 
  
 | 
    private ConfigXml conf = null ; 
 | 
    private Document doc = null ; 
 | 
    private boolean showStartInfo = false ; 
 | 
     
 | 
    private String RmiSvUrl ; 
 | 
    private String TcpSvUrl ; 
 | 
     
 | 
    private List<UnitInterface> units = new ArrayList<UnitInterface>() ; 
 | 
  
 | 
    /* 
 | 
     * @param args 参数 
 | 
    public static void main(String[] args) { 
 | 
        new Server().startServer(); 
 | 
    } 
 | 
    */ 
 | 
    /** 
 | 
     * 启动服务 
 | 
      */ 
 | 
    public void startServer(){ 
 | 
//        try { 
 | 
//            URL url = Server.class.getResource("/config/sv.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(); 
 | 
        long start = System.currentTimeMillis() ; 
 | 
        try { 
 | 
            //ConfigProperties.init(sv.getClass().getResourceAsStream("/config/config.properties"), false); 
 | 
             
 | 
            sv.conf = new ConfigXml() ; 
 | 
            sv.doc = sv.conf.createDom(sv.getClass(), "config.xml") ; 
 | 
            //////////////// 
 | 
            //服务 配置 
 | 
            sv.showStartInfo = sv.conf.getSetAttrBoolean(sv.doc, "config.server", "showStartInfo", null, null) ; 
 | 
  
 | 
            sv.startUnits() ; 
 | 
             
 | 
            String svName ; 
 | 
            try{ 
 | 
                svName = sv.conf.getSetAttrTxt(sv.doc, "config.server", "name", null, false, null) ; 
 | 
            }catch(Exception e){ 
 | 
                svName = "" ; 
 | 
            } 
 | 
            svName += (ServerProperties.isLowPower?"(低功耗)": "") + "-" ; 
 | 
             
 | 
            String company ; 
 | 
            try{ 
 | 
                company = sv.conf.getSetAttrTxt(sv.doc, "config.server", "company", null, true, null) ; 
 | 
            }catch(Exception e){ 
 | 
                company = "" ; 
 | 
            } 
 | 
            System.out.println("OOOOOOOOOO           OOOOOOOO       OOOOOOOO") ; 
 | 
            System.out.println("@@@@@@@@@@@@@@@@#O    $@@@@@@@@&    @@@@@@@@#") ;        
 | 
            System.out.println("@@@@@@@@@@@@@@@@@@@#    @@@@@@@@# $@@@@@@@@&") ;         
 | 
            System.out.println("@@@@@@@@@@@@@@@@@@@@@#   #@@@@@@@@@@@@@@@@O") ;     
 | 
            System.out.println("@@@@@@@@@@@@@@@@@@@@@@@   &@@@@@@@@@@@@@@") ;            
 | 
            System.out.println("@@@@@@$      $@@@@@@@@@&   O@@@@@@@@@@@#") ;         
 | 
            System.out.println("@@@@@@$        @@@@@@@@@     @@@@@@@@@&      " + svName + "RtuMw 1.0.00" ) ;              
 | 
            System.out.println("@@@@@@$        @@@@@@@@@     &@@@@@@@@") ; 
 | 
            if(sv.TcpSvUrl != null){ 
 | 
                System.out.println("@@@@@@$       O@@@@@@@@@     &@@@@@@@@       TcpSv " + sv.TcpSvUrl ) ;               
 | 
            }else{ 
 | 
                System.out.println("@@@@@@$       O@@@@@@@@@     &@@@@@@@@") ;               
 | 
            } 
 | 
            if(sv.RmiSvUrl != null){ 
 | 
                System.out.println("@@@@@@$      #@@@@@@@@@$     &@@@@@@@@       RmiSv " + sv.RmiSvUrl ) ;         
 | 
            }else{ 
 | 
                System.out.println("@@@@@@$      #@@@@@@@@@$     &@@@@@@@@" ) ;         
 | 
            } 
 | 
            System.out.println("@@@@@@@@@@@@@@@@@@@@@@#      &@@@@@@@@       Runing in standalone mode" ) ;     
 | 
            System.out.println("@@@@@@@@@@@@@@@@@@@@@&       &@@@@@@@@       Startup in " + (System.currentTimeMillis() - start) + " MS" ) ;               
 | 
            System.out.println("@@@@@@@@@@@@@@@@@@@#         &@@@@@@@@       " + company) ;             
 | 
            System.out.println("@@@@@@@@@@@@@@@@#O           &@@@@@@@@") ;               
 | 
  
 | 
        }catch(Exception e){ 
 | 
            e.printStackTrace(); 
 | 
        } 
 | 
    } 
 | 
     
 | 
    private void startUnits(){ 
 | 
        try { 
 | 
            /////////////// 
 | 
            //基本配置 
 | 
            ServerProperties.isLowPower = conf.getSetAttrBoolean(doc, "config.base", "isLowPower", null, null) ;  
 | 
            if(ServerProperties.isLowPower == null){ 
 | 
                ServerProperties.isLowPower = false ; 
 | 
            } 
 | 
            //在支持多通信协议时,只有RTU上线了,才能识别出该RTU实际用的通信协议,进而用此协议解析上行数据及构造下行命令。 
 | 
            //如果RTU未曾上线(通信中间件启动后该RTU未曾上线),那么在向它发送下行命令时,不能判断出其采用的协议,也不能构造命令,尤其是低功耗情况下,不上线是正常现象。 
 | 
            // 当只有一个协议情况下,在RTU未曾上线时,也能用此协议构造命令并缓存下来,尤其适合低功耗情况。 
 | 
            //onlyOne=true: 通信中间件当前只有一个协议    
 | 
            ServerProperties.onlyOneProtocol = conf.getSetAttrBoolean(doc, "config.base", "onlyOneProtocol", null, null) ;  
 | 
            if(ServerProperties.onlyOneProtocol == null){ 
 | 
                ServerProperties.onlyOneProtocol = false ; 
 | 
            } 
 | 
            //下行命令允许发送的最大次数X,即允许重发X-1 
 | 
            ServerProperties.downComandMaxResendTimes = conf.getSetAttrPlusInt(doc, "config.base", "downComandMaxResendTimes", null, 1, 5, null).byteValue() ; 
 | 
            //针对一个RTU,下发命令的时间间隔 
 | 
            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.offLineCachTimeout = conf.getSetAttrPlusInt(doc, "config.base", "offLineCachTimeout", null, 15, 172800, null) * 1000L ; 
 | 
            //TCP上行数据时刻缓存时长,当达到时长时,TCP上行数据时刻被清空,采用TCP上行数据时刻目的是,阻止上数据同时下发数据,因为RTU处理不过来 
 | 
            ServerProperties.lastUpDataTimeLive = conf.getSetAttrPlusInt(doc, "config.base", "lastUpDataTimeLive", null, 0, 5, null) * 1000L ; 
 | 
            //数据库数据id生成器的id后缀,0是默认的后缀,一般web系统应用,数据中间件id后缀大于等于1 
 | 
            ServerProperties.dbDataIdSuffix = conf.getSetAttrInt(doc, "config.base", "dbDataIdSuffix", null, 1, 9, null); 
 | 
            //上下行数据缓存队列中缓存数据个数的报警量,这个与现实项目所接水表数相关 
 | 
            ServerProperties.cacheUpDownDataWarnCount = conf.getSetAttrPlusInt(doc, "config.base", "cacheUpDownDataWarnCount", null, 1, null, null) ; 
 | 
            //上下行数据缓存队列中缓存数据个数的最大值,这个与现实项目所接水表数相关 
 | 
            ServerProperties.cacheUpDownDataMaxCount = conf.getSetAttrPlusInt(doc, "config.base", "cacheUpDownDataMaxCount", null, 1, null, null) ; 
 | 
            if(ServerProperties.cacheUpDownDataMaxCount <= ServerProperties.cacheUpDownDataWarnCount){ 
 | 
                throw new Exception("cacheUpDownDataMaxCount必须大于cacheUpDownDataWarnCount") ; 
 | 
            } 
 | 
  
 | 
            //设置ID生成器的后缀 
 | 
            IDLongGenerator.setSuffix(ServerProperties.dbDataIdSuffix.intValue()); 
 | 
  
 | 
  
 | 
            //////////////// 
 | 
            //协议模块 
 | 
            ProtocolConfigVo protoVo = new ProtocolConfigVo(); 
 | 
            protoVo.centerAddr = conf.getSetAttrPlusInt(doc, "config.protocol", "centerAddr", null, 1, 4, null) ; 
 | 
            protoVo.synchroRtuClock = conf.getSetAttrBoolean(doc, "config.protocol", "synchroRtuClock", null, null) ;  
 | 
            //当RTU与服务器时钟相差一定秒钟后,进行校时 
 | 
            protoVo.synchroRtuClockTimepieces = 1000 * conf.getSetAttrPlusInt(doc, "config.protocol", "synchroRtuClockTimepieces", null, null, null, null) ;  
 | 
            protoVo.showStartInfo = showStartInfo ; 
 | 
            AdapterImp_ProtocolUnit protoAdap = new AdapterImp_ProtocolUnit(); 
 | 
            protoAdap.setConfig(protoVo); 
 | 
            ProtocolUnit protoUnit = ProtocolUnit.getInstance(); 
 | 
            protoUnit.setAdapter(protoAdap); 
 | 
            protoUnit.start(new UnitStartedCallbackInterface(){ 
 | 
                @Override 
 | 
                public void call(Object obj) { 
 | 
                } 
 | 
            }); 
 | 
            units.add(protoUnit) ; 
 | 
             
 | 
            //////////////////////////////////////////////////////// 
 | 
            //支持模块: springHibernate和 线程池 
 | 
            SupportUnitConfigVo supVo = new SupportUnitConfigVo() ; 
 | 
            //短工作时长线程池,线程负责用时较短的工作任务 
 | 
            supVo.short_maxThread = conf.getSetAttrPlusInt(doc, "config.support", "short_maxThread", null, -1, 1000, null) ;//池中最大线程数为所有CPU核数+1 
 | 
            if(supVo.short_maxThread < 0){ 
 | 
                supVo.short_maxThread = -1 ; 
 | 
            } 
 | 
            supVo.short_minThread = conf.getSetAttrPlusInt(doc, "config.support", "short_minThread", null, -1, 100, null) ;//池中最小线程数 
 | 
            if(supVo.short_minThread < 0){ 
 | 
                supVo.short_minThread = -1 ; 
 | 
            } 
 | 
            supVo.short_freeTimeout = conf.getSetAttrPlusInt(doc, "config.support", "short_freeTimeout", null, 1, 90, null) * 1000 ;//线程数空闲时长,若池中线程数量大于minThread,且有的线程空闲时长超过freeTimeout,则清除该线程,为了不清除,把minThread与maxThread设置相等 
 | 
            supVo.short_busyTimeout = conf.getSetAttrPlusInt(doc, "config.support", "short_busyTimeout", null, 1, 10, null) * 1000 ;//线程不间断工作时长(单位为秒)超时限,认为线程已经了崩溃,将强制清除,短工作时长设置为5秒 
 | 
            if(supVo.short_maxThread == 0 || supVo.short_minThread == 0){ 
 | 
                supVo.enableShortThreadPool = false ; 
 | 
            }else{ 
 | 
                supVo.enableShortThreadPool = true ; 
 | 
            } 
 | 
  
 | 
            //长工作时长线程池,线程负责用时较长的工作任务 
 | 
            supVo.long_maxThread = conf.getSetAttrInt(doc, "config.support", "long_maxThread", null, -1, 1000, null)  ;//池中最大线程数,若为-1,不受限制 
 | 
            if(supVo.long_maxThread < 0){ 
 | 
                supVo.long_maxThread = -1 ; 
 | 
            } 
 | 
            supVo.long_minThread = conf.getSetAttrPlusInt(doc, "config.support", "long_minThread", null, -1, 100, null) ;//池中最小线程数 
 | 
            if(supVo.long_minThread < 0){ 
 | 
                supVo.long_minThread = -1 ; 
 | 
            } 
 | 
            supVo.long_freeTimeout = conf.getSetAttrPlusInt(doc, "config.support", "long_freeTimeout", null, 1, 90, null) * 1000 ;//线程数空闲时长,若池中线程数量大于minThread,且有的线程空闲时长超过freeTimeout,则清除该线程 
 | 
            supVo.long_busyTimeout = conf.getSetAttrInt(doc, "config.support", "long_busyTimeout", null, -1, 10, null) ;//线程不间断工作时长(单位为秒)超时限,若为-1,不受限制 
 | 
            if(supVo.long_busyTimeout < 0){ 
 | 
                supVo.long_busyTimeout = -1 ; 
 | 
            } 
 | 
            if(supVo.long_maxThread == 0 || supVo.long_minThread == 0){ 
 | 
                supVo.enableLongThreadPool = false ; 
 | 
            }else{ 
 | 
                supVo.enableLongThreadPool = true ; 
 | 
            } 
 | 
  
 | 
            supVo.showStartInfo = showStartInfo ; 
 | 
             
 | 
            AdapterImp_SupportUnit supAdap = new AdapterImp_SupportUnit() ; 
 | 
            supAdap.setConfig(supVo); 
 | 
            SupportUnit supUnit = SupportUnit.getInstance() ; 
 | 
            supUnit.setAdapter(supAdap); 
 | 
            supUnit.start(new UnitStartedCallbackInterface(){ 
 | 
                @Override 
 | 
                public void call(Object obj) { 
 | 
                } 
 | 
            }); 
 | 
            units.add(supUnit) ; 
 | 
             
 | 
                     
 | 
            ///////////////////////// 
 | 
            //资源模块 
 | 
            ResourceUnitConfigVo resVo = new ResourceUnitConfigVo() ; 
 | 
            //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) ; 
 | 
            //RTU日志文件最大文件数 
 | 
            resVo.rtuLogFileMaxCount = conf.getSetAttrPlusInt(doc, "config.resource", "rtuLogFileMaxCount", null, 1, 10, null) ;  
 | 
             
 | 
            //Rtu状态监视间隔(分钟) 
 | 
            resVo.monitorInterval = conf.getSetAttrPlusInt(doc, "config.resource", "monitorInterval", null, 1, 5, null) ;  
 | 
            //Rtu状态存数据库间隔(分钟) 
 | 
            resVo.saveDbInterval = conf.getSetAttrPlusInt(doc, "config.resource", "saveDbInterval", null, 5, 20, null) ;    
 | 
            //Rtu无数据上传达到此值,则认为不在线了(分钟) 
 | 
            //注意:noUpDataLimitTime在元素config.protocol中 
 | 
            //resVo.noUpDataLimitTime = conf.getSetAttrPlusInt(doc, "config.protocol", "noUpDataLimitTime", null, 30, 60, null) ;   
 | 
            AdapterImp_ResourceUnit resAdap = new AdapterImp_ResourceUnit() ; 
 | 
            resAdap.setConfig(resVo); 
 | 
            ResourceUnit resUnit = ResourceUnit.getInstance() ; 
 | 
            resUnit.setAdapter(resAdap); 
 | 
            //当前支持spring + hibernate 
 | 
            resUnit.setSpringContext(SpringContextUtil.getApplicationContext()); 
 | 
  
 | 
            resUnit.start(new UnitStartedCallbackInterface(){ 
 | 
                @Override 
 | 
                public void call(Object obj) { 
 | 
                } 
 | 
            }); 
 | 
            units.add(resUnit) ; 
 | 
  
 | 
             
 | 
            ///////////////// 
 | 
            //RMI模块 
 | 
            RmiConfigVo rmiVo = new RmiConfigVo(); 
 | 
            rmiVo.enable = conf.getSetAttrBoolean(doc, "config.rmi", "enable", null, null) ; 
 | 
            if(rmiVo.enable){ 
 | 
                rmiVo.port = conf.getSetAttrPlusInt(doc, "config.rmi", "port", null, 100, 65535, null); 
 | 
                rmiVo.context = conf.getSetAttrTxt(doc, "config.rmi", "context", null, false, null); 
 | 
                rmiVo.showStartInfo = showStartInfo ; 
 | 
                AdapterImp_RmiUnit rmiAdap = new AdapterImp_RmiUnit(); 
 | 
                rmiAdap.setConfig(rmiVo); 
 | 
                RmiUnit rmiUnit = RmiUnit.getInstance(); 
 | 
                rmiUnit.setAdapter(rmiAdap); 
 | 
                rmiUnit.start(new UnitStartedCallbackInterface(){ 
 | 
                    @Override 
 | 
                    public void call(Object obj) { 
 | 
                    } 
 | 
                }); 
 | 
                RmiSvUrl = "[ip]:" + rmiVo.port + "/" + rmiVo.context ; 
 | 
                units.add(rmiUnit) ; 
 | 
            } 
 | 
  
 | 
            // /////////////// 
 | 
            // 核心 
 | 
            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.queueWarnSize = ServerProperties.cacheUpDownDataWarnCount ; 
 | 
            coreConfVo.queueMaxSize = ServerProperties.cacheUpDownDataMaxCount ; 
 | 
            coreConfVo.showStartInfo = showStartInfo ; 
 | 
            AdapterImp_CoreUnit coreAdap = new AdapterImp_CoreUnit(); 
 | 
            coreAdap.setConfig(coreConfVo); 
 | 
            CoreUnit coreUnit = CoreUnit.getInstance(); 
 | 
            coreUnit.setAdapter(coreAdap); 
 | 
            CoreUnit.addConstantTask(new ToRtuConstantTask()); 
 | 
            CoreUnit.addConstantTask(new BusiConstantTask()); 
 | 
            coreUnit.start(new UnitStartedCallbackInterface(){ 
 | 
                @Override 
 | 
                public void call(Object obj) { 
 | 
                } 
 | 
            }); 
 | 
            units.add(coreUnit) ; 
 | 
  
 | 
  
 | 
            // /////////////// 
 | 
            // TCP 模块 
 | 
            TcpConfigVo tcpVo = new TcpConfigVo(); 
 | 
            tcpVo.enable = conf.getSetAttrBoolean(doc, "config.tcp", "enable", null, null) ; 
 | 
            if(tcpVo.enable){     
 | 
                tcpVo.port = conf.getSetAttrPlusInt(doc, "config.tcp", "port", null, 100, 65535, null); 
 | 
                tcpVo.processors = conf.getSetAttrPlusInt(doc, "config.tcp", "processors", null, 1, 100, null); 
 | 
                tcpVo.idle = conf.getSetAttrPlusInt(doc, "config.tcp", "idle", null, 1, 20, null);// 10分钟 
 | 
                tcpVo.showStartInfo = showStartInfo ; 
 | 
                AdapterImp_TcpUnit tcpAdap = new AdapterImp_TcpUnit(); 
 | 
                tcpAdap.setConfig(tcpVo); 
 | 
                TcpUnit tcpUnit = TcpUnit.getInstance(); 
 | 
                tcpUnit.setAdapter(tcpAdap); 
 | 
                tcpUnit.start(new UnitStartedCallbackInterface(){ 
 | 
                    @Override 
 | 
                    public void call(Object obj) { 
 | 
                    } 
 | 
                }); 
 | 
                TcpSvUrl = "[ip]:" + tcpVo.port ; 
 | 
                units.add(tcpUnit) ; 
 | 
            }     
 | 
        } catch (Exception e) { 
 | 
            e.printStackTrace(); 
 | 
        }         
 | 
    } 
 | 
     
 | 
  
 | 
} 
 |