GgitsTsinfoServerApplication.java 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. package com.sig.ggits.tsinfo.server;
  2. import com.its.common.spring.SpringUtils;
  3. import com.sig.ggits.tsinfo.server.service.TsinfoFileWatcherService;
  4. import lombok.extern.slf4j.Slf4j;
  5. import org.springframework.beans.factory.DisposableBean;
  6. import org.springframework.beans.factory.InitializingBean;
  7. import org.springframework.boot.Banner;
  8. import org.springframework.boot.CommandLineRunner;
  9. import org.springframework.boot.SpringApplication;
  10. import org.springframework.boot.autoconfigure.SpringBootApplication;
  11. import org.springframework.boot.builder.SpringApplicationBuilder;
  12. import org.springframework.boot.context.ApplicationPidFileWriter;
  13. import org.springframework.context.ApplicationListener;
  14. import org.springframework.context.annotation.ComponentScan;
  15. import org.springframework.context.annotation.Configuration;
  16. import org.springframework.context.event.ContextClosedEvent;
  17. import org.springframework.scheduling.annotation.EnableAsync;
  18. import java.text.SimpleDateFormat;
  19. import java.util.Date;
  20. @Slf4j
  21. @EnableAsync
  22. @Configuration
  23. @SpringBootApplication//(exclude = {DataSourceAutoConfiguration.class, HibernateJpaAutoConfiguration.class})
  24. @ComponentScan(basePackages = {"com.its.common.spring", "com.sig.ggits.tsinfo.server.config", "com.sig.ggits.tsinfo.server"})
  25. public class GgitsTsinfoServerApplication implements CommandLineRunner, ApplicationListener<ContextClosedEvent>, InitializingBean, DisposableBean {
  26. public static final String APPLICATION_NAME = "ggits-tsinfo-server";
  27. public static void main(String[] args) {
  28. SpringApplication application = new SpringApplicationBuilder()
  29. .sources(GgitsTsinfoServerApplication.class)
  30. .listeners(new ApplicationPidFileWriter("./conf/" + APPLICATION_NAME + ".pid"))
  31. .build();
  32. application.setBannerMode(Banner.Mode.OFF);
  33. application.run(args);
  34. }
  35. @Override
  36. public void run(String... args) throws Exception {
  37. SimpleDateFormat sdfDate = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  38. log.info("");
  39. log.info("");
  40. log.info("************************************************************************************");
  41. log.info("** **");
  42. log.info("** UTIC Signal System **");
  43. log.info("** GGITS Traffic Signal State Gather Server Program. **");
  44. log.info("** **");
  45. log.info("** [ver.1.0] **");
  46. log.info("** startup: {}", sdfDate.format(new Date()));
  47. log.info("** HOME: {}", System.getProperty("user.home"));
  48. log.info("************************************************************************************");
  49. TsinfoFileWatcherService tsinfoFileWatcherService = SpringUtils.getBean(TsinfoFileWatcherService.class);
  50. tsinfoFileWatcherService.start();
  51. }
  52. public void terminateApplication() {
  53. }
  54. @Override
  55. public void onApplicationEvent(ContextClosedEvent event) {
  56. SimpleDateFormat sdfDate = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  57. log.error("Application Terminated: {}, {}", sdfDate.format(new Date()), event);
  58. terminateApplication();
  59. }
  60. @Override
  61. public void destroy() throws Exception {
  62. log.error("Application destroy");
  63. }
  64. @Override
  65. public void afterPropertiesSet() throws Exception {
  66. }
  67. }