|
|
@ -35,18 +35,18 @@ import java.util.concurrent.ThreadPoolExecutor;
|
|
|
|
public abstract class AbstractThreadPoolRuntime {
|
|
|
|
public abstract class AbstractThreadPoolRuntime {
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* Supplement.
|
|
|
|
* Supplemental thread pool runtime information.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* @param threadPoolRunStateInfo
|
|
|
|
* @param threadPoolRunStateInfo thread-pool run state info
|
|
|
|
* @return
|
|
|
|
* @return thread-pool run state info
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
public abstract ThreadPoolRunStateInfo supplement(ThreadPoolRunStateInfo threadPoolRunStateInfo);
|
|
|
|
public abstract ThreadPoolRunStateInfo supplement(ThreadPoolRunStateInfo threadPoolRunStateInfo);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* Get pool run state.
|
|
|
|
* Get pool run state.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* @param threadPoolId
|
|
|
|
* @param threadPoolId thread-pool id
|
|
|
|
* @return
|
|
|
|
* @return thread-pool run state info
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
public ThreadPoolRunStateInfo getPoolRunState(String threadPoolId) {
|
|
|
|
public ThreadPoolRunStateInfo getPoolRunState(String threadPoolId) {
|
|
|
|
DynamicThreadPoolWrapper executorService = GlobalThreadPoolManage.getExecutorService(threadPoolId);
|
|
|
|
DynamicThreadPoolWrapper executorService = GlobalThreadPoolManage.getExecutorService(threadPoolId);
|
|
|
@ -57,56 +57,34 @@ public abstract class AbstractThreadPoolRuntime {
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* Get pool run state.
|
|
|
|
* Get pool run state.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* @param threadPoolId
|
|
|
|
* @param threadPoolId thread-pool id
|
|
|
|
* @param executor
|
|
|
|
* @param executor executor
|
|
|
|
* @return
|
|
|
|
* @return thread-pool run state info
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
public ThreadPoolRunStateInfo getPoolRunState(String threadPoolId, Executor executor) {
|
|
|
|
public ThreadPoolRunStateInfo getPoolRunState(String threadPoolId, Executor executor) {
|
|
|
|
ThreadPoolRunStateInfo stateInfo = new ThreadPoolRunStateInfo();
|
|
|
|
ThreadPoolExecutor actualExecutor = (ThreadPoolExecutor) executor;
|
|
|
|
ThreadPoolExecutor pool = (ThreadPoolExecutor) executor;
|
|
|
|
int activeCount = actualExecutor.getActiveCount();
|
|
|
|
// 核心线程数
|
|
|
|
int largestPoolSize = actualExecutor.getLargestPoolSize();
|
|
|
|
int corePoolSize = pool.getCorePoolSize();
|
|
|
|
BlockingQueue<Runnable> blockingQueue = actualExecutor.getQueue();
|
|
|
|
// 最大线程数
|
|
|
|
long rejectCount = actualExecutor instanceof DynamicThreadPoolExecutor ? ((DynamicThreadPoolExecutor) actualExecutor).getRejectCountNum() : -1L;
|
|
|
|
int maximumPoolSize = pool.getMaximumPoolSize();
|
|
|
|
ThreadPoolRunStateInfo stateInfo = ThreadPoolRunStateInfo.builder()
|
|
|
|
// 线程池当前线程数 (有锁)
|
|
|
|
.tpId(threadPoolId)
|
|
|
|
int poolSize = pool.getPoolSize();
|
|
|
|
.activeSize(activeCount)
|
|
|
|
// 活跃线程数 (有锁)
|
|
|
|
.poolSize(actualExecutor.getPoolSize())
|
|
|
|
int activeCount = pool.getActiveCount();
|
|
|
|
.completedTaskCount(actualExecutor.getCompletedTaskCount())
|
|
|
|
// 同时进入池中的最大线程数 (有锁)
|
|
|
|
.largestPoolSize(largestPoolSize)
|
|
|
|
int largestPoolSize = pool.getLargestPoolSize();
|
|
|
|
.currentLoad(CalculateUtil.divide(activeCount, actualExecutor.getMaximumPoolSize()) + "")
|
|
|
|
// 线程池中执行任务总数量 (有锁)
|
|
|
|
.clientLastRefreshTime(LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")))
|
|
|
|
long completedTaskCount = pool.getCompletedTaskCount();
|
|
|
|
.peakLoad(CalculateUtil.divide(largestPoolSize, actualExecutor.getMaximumPoolSize()) + "")
|
|
|
|
// 当前负载
|
|
|
|
.queueSize(blockingQueue.size())
|
|
|
|
String currentLoad = CalculateUtil.divide(activeCount, maximumPoolSize) + "";
|
|
|
|
.queueRemainingCapacity(blockingQueue.remainingCapacity())
|
|
|
|
// 峰值负载
|
|
|
|
.rejectCount(rejectCount)
|
|
|
|
String peakLoad = CalculateUtil.divide(largestPoolSize, maximumPoolSize) + "";
|
|
|
|
.timestamp(System.currentTimeMillis())
|
|
|
|
BlockingQueue<Runnable> queue = pool.getQueue();
|
|
|
|
.build();
|
|
|
|
// 队列元素个数
|
|
|
|
stateInfo.setCoreSize(actualExecutor.getCorePoolSize());
|
|
|
|
int queueSize = queue.size();
|
|
|
|
stateInfo.setMaximumSize(actualExecutor.getMaximumPoolSize());
|
|
|
|
// 队列类型
|
|
|
|
stateInfo.setQueueType(blockingQueue.getClass().getSimpleName());
|
|
|
|
String queueType = queue.getClass().getSimpleName();
|
|
|
|
stateInfo.setQueueCapacity(blockingQueue.size() + blockingQueue.remainingCapacity());
|
|
|
|
// 队列剩余容量
|
|
|
|
|
|
|
|
int remainingCapacity = queue.remainingCapacity();
|
|
|
|
|
|
|
|
// 队列容量
|
|
|
|
|
|
|
|
int queueCapacity = queueSize + remainingCapacity;
|
|
|
|
|
|
|
|
stateInfo.setCoreSize(corePoolSize);
|
|
|
|
|
|
|
|
stateInfo.setTpId(threadPoolId);
|
|
|
|
|
|
|
|
stateInfo.setPoolSize(poolSize);
|
|
|
|
|
|
|
|
stateInfo.setMaximumSize(maximumPoolSize);
|
|
|
|
|
|
|
|
stateInfo.setActiveSize(activeCount);
|
|
|
|
|
|
|
|
stateInfo.setCurrentLoad(currentLoad);
|
|
|
|
|
|
|
|
stateInfo.setPeakLoad(peakLoad);
|
|
|
|
|
|
|
|
stateInfo.setQueueType(queueType);
|
|
|
|
|
|
|
|
stateInfo.setQueueSize(queueSize);
|
|
|
|
|
|
|
|
stateInfo.setQueueCapacity(queueCapacity);
|
|
|
|
|
|
|
|
stateInfo.setQueueRemainingCapacity(remainingCapacity);
|
|
|
|
|
|
|
|
stateInfo.setLargestPoolSize(largestPoolSize);
|
|
|
|
|
|
|
|
stateInfo.setCompletedTaskCount(completedTaskCount);
|
|
|
|
|
|
|
|
long rejectCount =
|
|
|
|
|
|
|
|
pool instanceof DynamicThreadPoolExecutor ? ((DynamicThreadPoolExecutor) pool).getRejectCountNum() : -1L;
|
|
|
|
|
|
|
|
stateInfo.setRejectCount(rejectCount);
|
|
|
|
|
|
|
|
stateInfo.setClientLastRefreshTime(LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
|
|
|
|
|
|
|
|
stateInfo.setTimestamp(System.currentTimeMillis());
|
|
|
|
|
|
|
|
return supplement(stateInfo);
|
|
|
|
return supplement(stateInfo);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|