ItsRotaServerApplication.java 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. package com.its.rota.server;
  2. import com.its.rota.server.common.SpringUtils;
  3. import com.its.rota.server.process.dbms.DbmsDataProcess;
  4. import com.its.rota.server.xnet.server.process.work.DataPacketProcess;
  5. import com.its.rota.server.repository.ApplicationRepository;
  6. import com.its.rota.server.service.UnitSystService;
  7. import com.its.rota.server.xnet.server.ItsAsnCommServerService;
  8. import lombok.extern.slf4j.Slf4j;
  9. import org.springframework.beans.factory.DisposableBean;
  10. import org.springframework.beans.factory.InitializingBean;
  11. import org.springframework.boot.Banner;
  12. import org.springframework.boot.CommandLineRunner;
  13. import org.springframework.boot.SpringApplication;
  14. import org.springframework.boot.autoconfigure.SpringBootApplication;
  15. import org.springframework.boot.builder.SpringApplicationBuilder;
  16. import org.springframework.boot.context.ApplicationPidFileWriter;
  17. import org.springframework.context.ApplicationListener;
  18. import org.springframework.context.annotation.ComponentScan;
  19. import org.springframework.context.event.ContextClosedEvent;
  20. import org.springframework.transaction.annotation.EnableTransactionManagement;
  21. import java.text.SimpleDateFormat;
  22. import java.util.Date;
  23. @Slf4j
  24. @SpringBootApplication
  25. @EnableTransactionManagement
  26. @ComponentScan(basePackages = {"com.its.app.common", "com.its.rota.server.config", "com.its.rota.server"})
  27. public class ItsRotaServerApplication implements CommandLineRunner, ApplicationListener<ContextClosedEvent>, InitializingBean, DisposableBean {
  28. private static final String APPLICATION_NAME = "its-rota-server";
  29. public static void main(String[] args) {
  30. SpringApplication application = new SpringApplicationBuilder()
  31. .sources(ItsRotaServerApplication.class)
  32. .listeners(new ApplicationPidFileWriter("./conf/" + APPLICATION_NAME + ".pid"))
  33. .build();
  34. application.setBannerMode(Banner.Mode.OFF);
  35. application.run(args);
  36. }
  37. @Override
  38. public void run(String... args) throws Exception {
  39. SimpleDateFormat sdfDate = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  40. log.info("");
  41. log.info("");
  42. log.info("************************************************************************************");
  43. log.info("** **");
  44. log.info("** UTIC ITS ROTA System **");
  45. log.info("** UTIC ITS ROTA Communication Server Program. **");
  46. log.info("** **");
  47. log.info("** [ver.1.0] **");
  48. log.info("** startup: {}", sdfDate.format(new Date()));
  49. log.info("** HOME: {}", System.getProperty("user.home"));
  50. log.info("************************************************************************************");
  51. DbmsDataProcess dbmsDataProcess = SpringUtils.getBean(DbmsDataProcess.class);
  52. dbmsDataProcess.run();
  53. ApplicationRepository applicationRepository = SpringUtils.getBean(ApplicationRepository.class);
  54. applicationRepository.loadDb();
  55. DataPacketProcess dataPacketProcess = SpringUtils.getBean(DataPacketProcess.class);
  56. dataPacketProcess.run();
  57. ItsAsnCommServerService itsAsnCommServerService = SpringUtils.getBean(ItsAsnCommServerService.class);
  58. itsAsnCommServerService.run();
  59. }
  60. public void terminateApplication() {
  61. ApplicationRepository applicationRepository = SpringUtils.getBean(ApplicationRepository.class);
  62. applicationRepository.terminate();
  63. UnitSystService unitSystService = SpringUtils.getBean(UnitSystService.class);
  64. unitSystService.updateUnitSystStts(false);
  65. ItsAsnCommServerService itsAsnCommServerService = SpringUtils.getBean(ItsAsnCommServerService.class);
  66. itsAsnCommServerService.shutdown();
  67. }
  68. @Override
  69. public void onApplicationEvent(ContextClosedEvent contextClosedEvent) {
  70. SimpleDateFormat sdfDate = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  71. log.error("Application Terminated: {}, {}", sdfDate.format(new Date()), contextClosedEvent);
  72. terminateApplication();
  73. }
  74. @Override
  75. public void destroy() throws Exception {
  76. log.error("Application destroy");
  77. }
  78. @Override
  79. public void afterPropertiesSet() throws Exception {
  80. log.info("Application afterPropertiesSet");
  81. }
  82. }