AbstractDbmsJobProcess.java 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. package com.its.wthr.process;
  2. import com.its.app.AppUtils;
  3. import com.its.wthr.config.ThreadPoolInitializer;
  4. import com.its.wthr.mapper.UnitSystMapper;
  5. import com.its.wthr.vo.UnitSystSttsVo;
  6. import lombok.extern.slf4j.Slf4j;
  7. import javax.annotation.PostConstruct;
  8. import java.util.concurrent.Executors;
  9. import java.util.concurrent.LinkedBlockingQueue;
  10. import java.util.concurrent.ThreadPoolExecutor;
  11. @Slf4j
  12. public abstract class AbstractDbmsJobProcess {
  13. public static LinkedBlockingQueue<DbmsJobData> DBMS_DATA_QUEUE = new LinkedBlockingQueue<>(1000);
  14. private UnitSystMapper unitSystMapper;
  15. private final ThreadPoolExecutor taskExecutor = (ThreadPoolExecutor)Executors.newFixedThreadPool(1);
  16. int MAX_CORE = Runtime.getRuntime().availableProcessors();
  17. @PostConstruct
  18. void init() {
  19. this.unitSystMapper = (UnitSystMapper) AppUtils.getBean(UnitSystMapper.class);
  20. postConstruct();
  21. }
  22. protected abstract void postConstruct();
  23. public abstract void process(DbmsJobData data);
  24. public void run() {
  25. log.info("AbstractDbmsJobProcess.run: Start.");
  26. if (this.MAX_CORE < 8) {
  27. this.MAX_CORE = 8;
  28. }
  29. ThreadPoolInitializer poolInitializer = (ThreadPoolInitializer) AppUtils.getBean(ThreadPoolInitializer.class);
  30. int executePool = Math.max(this.MAX_CORE, poolInitializer.getWork());
  31. for (int ii = 0; ii < executePool; ii++) {
  32. log.info("AbstractDbmsJobProcess.Task: {}", ii);
  33. this.taskExecutor.execute(() -> {
  34. while (true) {
  35. try {
  36. DbmsJobData dbmsJobData = AbstractDbmsJobProcess.DBMS_DATA_QUEUE.take();
  37. if (dbmsJobData != null) {
  38. //log.info("DBMS_DATA_QUEUE..take: {} EA, {}, {}", DBMS_DATA_QUEUE.size(), dbmsJobData, Thread.currentThread().getName());
  39. DbmsJobTask handler = (DbmsJobTask) AppUtils.getBean(DbmsJobTask.class);
  40. handler.run(this, dbmsJobData);
  41. }
  42. else {
  43. log.error("AbstractDbmsJobProcess.Task: Received data null");
  44. }
  45. }
  46. catch (Exception e) {
  47. log.error("AbstractDbmsJobProcess.Task: Exception: {}", e.getMessage(), e);
  48. }
  49. }
  50. });
  51. }
  52. log.info("AbstractDbmsJobProcess.run: ..End.");
  53. }
  54. /*
  55. * 작업큐에 데이터 추가
  56. */
  57. public boolean add(DbmsJobData dbmsJobData) {
  58. boolean offer = false;
  59. try {
  60. //offer => full -> return
  61. //add => full -> wait
  62. //큐가 차더라도 바로 리턴함.
  63. offer = AbstractDbmsJobProcess.DBMS_DATA_QUEUE.offer(dbmsJobData);
  64. if (!offer) {
  65. log.error("DbmsJobProcess.add: Queue Full Error, Size: {} EA", DBMS_DATA_QUEUE.size());
  66. }
  67. } catch (Exception e) {
  68. log.error("DbmsJobProcess.add: Exception: {}", e.getMessage(), e);
  69. }
  70. return offer;
  71. }
  72. public static boolean addQ(DbmsJobData dbmsJobData) {
  73. try {
  74. //offer => full -> return
  75. //add => full -> wait
  76. //큐가 차더라도 바로 리턴함.
  77. if (!AbstractDbmsJobProcess.DBMS_DATA_QUEUE.offer(dbmsJobData)) {
  78. log.error("AbstractDbmsJobProcess.add: Queue Full Error, Size: {} EA, {}", DBMS_DATA_QUEUE.size(), dbmsJobData);
  79. return false;
  80. }
  81. //log.info("DBMS_DATA_QUEUE.offer: {} EA, {}", DBMS_DATA_QUEUE.size(), dbmsJobData);
  82. return true;
  83. } catch (Exception e) {
  84. log.error("AbstractDbmsJobProcess.add: Exception: {}", e.getMessage(), e);
  85. }
  86. return false;
  87. }
  88. public void runJob(DbmsJobData dbmsJobData) {
  89. //log.info("AbstractDbmsJobProcess.runJob: type: {}, {}", dbmsJobData.getType(), Thread.currentThread().getName());
  90. if (dbmsJobData.getType() == DbmsJobType.DATA_TYPE_UNIT_SYST_STTS) {
  91. // UNIT 상태정보 관리는 라이브러리에서 수행한다.
  92. UnitSystSttsVo stts = (UnitSystSttsVo)dbmsJobData.getData();
  93. this.unitSystMapper.updateUnitSystStts(stts); // 상태정보 업데이트
  94. if (dbmsJobData.isHistory()) {
  95. this.unitSystMapper.insertUnitSystSttsHs(stts); // 상태정보 이력저장
  96. }
  97. }
  98. else {
  99. process(dbmsJobData);
  100. }
  101. }
  102. }