| New file | 
|  |  |  | 
|---|
|  |  |  | package com.dy.rtuMw; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.dy.common.mw.protocol.Command; | 
|---|
|  |  |  | import com.dy.common.mw.protocol.CommandType; | 
|---|
|  |  |  | import com.dy.rtuMw.server.local.CommandInnerDeaLer; | 
|---|
|  |  |  | import com.dy.rtuMw.server.local.localProtocol.CodeLocal; | 
|---|
|  |  |  | import lombok.extern.slf4j.Slf4j; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * @Author: liurunyu | 
|---|
|  |  |  | * @Date: 2024/8/6 9:51 | 
|---|
|  |  |  | * @Description 程序(控制台)关闭处理钩子类 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Slf4j | 
|---|
|  |  |  | public class ServerShutDownHook { | 
|---|
|  |  |  | public static void OnShutDown(){ | 
|---|
|  |  |  | Runtime.getRuntime().addShutdownHook(new Thread(){ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void run(){ | 
|---|
|  |  |  | try{ | 
|---|
|  |  |  | // 确保这段代码尽可能快速执行,避免影响JVM的关闭 | 
|---|
|  |  |  | log.info("程序(控制台)关闭钩子类执行"); | 
|---|
|  |  |  | Command com1 = new Command() ; | 
|---|
|  |  |  | com1.id = Command.defaultId ; | 
|---|
|  |  |  | com1.code = CodeLocal.stopTcpSv ; | 
|---|
|  |  |  | com1.type = CommandType.innerCommand ; | 
|---|
|  |  |  | new CommandInnerDeaLer().deal(com1) ; | 
|---|
|  |  |  | //Thread.sleep(100L);//实测不执行 | 
|---|
|  |  |  | log.info("关闭程序前,关闭了TCP服务"); | 
|---|
|  |  |  | Command com2 = new Command() ; | 
|---|
|  |  |  | com2.id = Command.defaultId ; | 
|---|
|  |  |  | com2.code = CodeLocal.stopMqttSv ; | 
|---|
|  |  |  | com2.type = CommandType.innerCommand ; | 
|---|
|  |  |  | new CommandInnerDeaLer().deal(com2) ; | 
|---|
|  |  |  | log.info("关闭程序前,关闭了MQTT服务"); | 
|---|
|  |  |  | }catch (Exception e){ | 
|---|
|  |  |  | log.error("程序(控制台)关闭钩子发生异常", e); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|