1
2
3
4
5
6
7
8
9
10
11 package com.jsql.util;
12
13 import com.jsql.model.InjectionModel;
14 import com.jsql.model.bean.database.AbstractElementDatabase;
15 import com.jsql.model.suspendable.AbstractSuspendable;
16 import com.jsql.model.suspendable.callable.ThreadFactoryCallable;
17 import org.apache.logging.log4j.LogManager;
18 import org.apache.logging.log4j.Logger;
19
20 import java.util.HashMap;
21 import java.util.Map;
22 import java.util.concurrent.ConcurrentHashMap;
23 import java.util.concurrent.ExecutorService;
24 import java.util.concurrent.Executors;
25 import java.util.concurrent.TimeUnit;
26
27
28
29
30
31
32
33 public final class ThreadUtil {
34
35 private static final Logger LOGGER = LogManager.getRootLogger();
36
37
38
39
40
41
42 private final Map<AbstractElementDatabase, AbstractSuspendable> suspendables = new ConcurrentHashMap<>(new HashMap<>());
43
44 private final InjectionModel injectionModel;
45
46 public ThreadUtil(InjectionModel injectionModel) {
47 this.injectionModel = injectionModel;
48 }
49
50
51
52
53
54
55
56 public void put(AbstractElementDatabase elementDatabase, AbstractSuspendable suspendable) {
57 this.suspendables.put(elementDatabase, suspendable);
58 }
59
60
61
62
63
64
65
66
67 public AbstractSuspendable get(AbstractElementDatabase elementDatabase) {
68 return this.suspendables.get(elementDatabase);
69 }
70
71
72
73
74
75
76 public void remove(AbstractElementDatabase elementDatabase) {
77 this.suspendables.remove(elementDatabase);
78 }
79
80
81
82
83
84 public void reset() {
85 this.suspendables.values().forEach(AbstractSuspendable::stop);
86 this.suspendables.clear();
87 }
88
89 public ExecutorService getExecutor(String nameThread) {
90 ExecutorService taskExecutor;
91
92 if (this.injectionModel.getMediatorUtils().getPreferencesUtil().isLimitingThreads()) {
93 int countThreads = this.injectionModel.getMediatorUtils().getPreferencesUtil().countLimitingThreads();
94 taskExecutor = Executors.newFixedThreadPool(countThreads, new ThreadFactoryCallable(nameThread));
95 } else {
96 taskExecutor = Executors.newCachedThreadPool(new ThreadFactoryCallable(nameThread));
97 }
98 return taskExecutor;
99 }
100
101 public void shutdown(ExecutorService taskExecutor) {
102 int timeout = 15;
103 if (this.injectionModel.getMediatorUtils().getPreferencesUtil().isConnectionTimeout()) {
104 timeout = this.injectionModel.getMediatorUtils().getPreferencesUtil().countConnectionTimeout();
105 }
106
107 try {
108 taskExecutor.shutdown();
109 if (!taskExecutor.awaitTermination(timeout, TimeUnit.SECONDS)) {
110 taskExecutor.shutdownNow();
111 }
112 } catch (InterruptedException e) {
113 LOGGER.log(LogLevelUtil.IGNORE, e, e);
114 Thread.currentThread().interrupt();
115 }
116 }
117 }