From 60211f59d2c85053533ed151adb2bdc5348dd342 Mon Sep 17 00:00:00 2001
From: liusuyi <1951119284@qq.com>
Date: 星期四, 01 八月 2024 09:51:12 +0800
Subject: [PATCH] 修改:会话消息独立线程池;线程池参数统一设置

---
 ard-work/src/main/java/com/ruoyi/sy/controller/ArdSyCarController.java |   75 +++++++++++++++++++++++++++++++++++++
 1 files changed, 75 insertions(+), 0 deletions(-)

diff --git a/ard-work/src/main/java/com/ruoyi/sy/controller/ArdSyCarController.java b/ard-work/src/main/java/com/ruoyi/sy/controller/ArdSyCarController.java
index 25dfa7a..3ed0961 100644
--- a/ard-work/src/main/java/com/ruoyi/sy/controller/ArdSyCarController.java
+++ b/ard-work/src/main/java/com/ruoyi/sy/controller/ArdSyCarController.java
@@ -316,6 +316,81 @@
         };
         passwordTimer.scheduleAtFixedRate(passwordTask,date,11000);
 
+        Timer lockRestartStateTimer = new Timer();//瀹氭椂鍚勪釜閿佺殑澶嶄綅鐘舵��
+        TimerTask lockRestartStateTask =new TimerTask(){
+            @Override
+            public void run(){
+                Thread thread = new Thread(){
+                    @Override
+                    public void run() {
+                        SysConfig config = new SysConfig();
+                        config.setConfigKey("syCarPT");
+                        List<SysConfig> sysConfigResult = sysConfigService.selectConfigList(config);
+                        String syURL = "";
+
+                        if(sysConfigResult.size() == 0){
+                            return;
+                        }else{
+                            syURL = sysConfigResult.get(0).getConfigValue();
+                        }
+                        String passwordMd5 = DigestUtils.md5Hex(password);
+                        Map<String, Object> LogInResult = sYClient.logIn(syURL, passwordMd5, userId);
+                        String sessionId = (String) LogInResult.get("sessionId");
+
+                        String finalSyURL = syURL;
+
+                        List<ArdTankLock> result = ardTankLockService.getArdTankLockAllWithState();//鏌ヨ鍏ㄩ儴鐢电閿佸強鏈�缁堢姸鎬�
+                        for(ArdTankLock ardTankLock : result){
+                            String restartState = ardTankLock.getRestartState();
+                            String sRestartState = "";
+                            if(ardTankLock.getArdTankLockState() != null){
+                                sRestartState = ardTankLock.getArdTankLockState().getRestartState();
+                            }
+
+                            if(sRestartState.equals("")){
+                                continue;
+                            }else{
+                                sRestartState = sRestartState.substring(0,2);
+                                if(!restartState.equals(sRestartState)){
+                                    Thread lockThread = new Thread(finalSyURL){
+                                        @Override
+                                        public void run() {
+                                            String process = "";
+                                            if(restartState.equals("寮�閿�")){
+                                                process = "01";
+                                            }else if(restartState.equals("鍏抽攣")){
+                                                process = "02";
+                                            }else{
+                                                return;
+                                            }
+
+                                            String lockNumHead = ardTankLock.getLockNum().substring(0,2);
+                                            String lockNumTail = ardTankLock.getLockNum().substring(2,4);
+                                            //璁$畻鏍¢獙
+                                            String checkNum = Integer.toHexString(Integer.parseInt(lockNumHead, 16) + Integer.parseInt(lockNumTail, 16) + Integer.parseInt("03", 16) + Integer.parseInt(process, 16));
+
+                                            if(checkNum.length() == 1){
+                                                checkNum = "0" + checkNum;
+                                            }else if(checkNum.length() > 2){
+                                                checkNum = checkNum.substring(checkNum.length() - 2,checkNum.length());
+                                            }
+
+                                            String paramsStr = "%7B%22type%22%3A%22ff%22%2C%22dataCnt%22%3A%22" + ardTankLock.getLockNum() + "03" + process + checkNum + "%22%7D";
+
+                                            sendCmd(finalSyURL,userId,ardTankLock.getCarId(),199,"DataDownTransfer", paramsStr,sessionId);
+                                        }
+                                    };
+                                    lockThread.start();
+                                }
+                            }
+                        }
+                    }
+                };
+                thread.start();
+            }
+        };
+        lockRestartStateTimer.scheduleAtFixedRate(lockRestartStateTask,date,9000);
+
     }
 
     /**

--
Gitblit v1.9.3