ItsOpServerApplication.java 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. package com.its.op;
  2. import com.its.op.config.AppUtils;
  3. import com.its.op.config.ProcessConfig;
  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.annotation.EnableAspectJAutoProxy;
  17. import org.springframework.context.event.ContextClosedEvent;
  18. import org.springframework.scheduling.annotation.EnableAsync;
  19. import org.springframework.web.bind.annotation.CrossOrigin;
  20. import java.text.SimpleDateFormat;
  21. import java.util.Date;
  22. @Slf4j
  23. @EnableAspectJAutoProxy
  24. @EnableAsync
  25. @Configuration
  26. @SpringBootApplication
  27. @ComponentScan(basePackages = {"com.its.op.config", "com.its.op.repository.mapper.*", "com.its.op"})
  28. @CrossOrigin("*")
  29. public class ItsOpServerApplication implements CommandLineRunner, ApplicationListener<ContextClosedEvent>, InitializingBean, DisposableBean {
  30. private static final String applicationName = "traf-prcs-server";
  31. public static void main(String[] args) {
  32. //System.setProperty("log4j.skipJansi", String.valueOf(true));
  33. SpringApplication application = new SpringApplicationBuilder()
  34. .sources(ItsOpServerApplication.class)
  35. .listeners(new ApplicationPidFileWriter("./conf/" + applicationName + ".pid"))
  36. .build();
  37. application.setBannerMode(Banner.Mode.OFF);
  38. application.run(args);
  39. }
  40. @Override
  41. public void run(String... args) throws Exception {
  42. ProcessConfig processConfig = (ProcessConfig) AppUtils.getBean(ProcessConfig.class);
  43. log.info("");
  44. log.info("");
  45. log.info("************************************************************************************");
  46. log.info("** **");
  47. log.info("** Intelligent Traffic System **");
  48. log.info("** Intelligent Traffic System Common Operating Server. **");
  49. log.info("** **");
  50. log.info("** [ver.1.0] **");
  51. log.info("** process: {}", processConfig.getId());
  52. log.info("** startup: {}", processConfig.getBootingDateTime());
  53. log.info("************************************************************************************");
  54. }
  55. @Override
  56. public void onApplicationEvent(ContextClosedEvent contextClosedEvent) {
  57. SimpleDateFormat sdfDate = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  58. log.error("Application Terminated: {}, {}", sdfDate.format(new Date()), contextClosedEvent.toString());
  59. }
  60. @Override
  61. public void destroy() throws Exception {
  62. }
  63. @Override
  64. public void afterPropertiesSet() throws Exception {
  65. }
  66. }