fix 1129: AbstractHystrixThreadPoolAdapter set BlockingQueueCapacity (#1130)

pull/1136/head
yangsanity 2 years ago committed by GitHub
parent 771d73f04a
commit 6df52eb796
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -32,6 +32,7 @@ import java.util.ArrayList;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.concurrent.BlockingQueue;
import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.ScheduledExecutorService; import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.ThreadPoolExecutor; import java.util.concurrent.ThreadPoolExecutor;
@ -67,9 +68,11 @@ public abstract class AbstractHystrixThreadPoolAdapter implements ThreadPoolAdap
ThreadPoolAdapterState result = new ThreadPoolAdapterState(); ThreadPoolAdapterState result = new ThreadPoolAdapterState();
ThreadPoolExecutor threadPoolExecutor = hystrixConsumeExecutor.get(identify); ThreadPoolExecutor threadPoolExecutor = hystrixConsumeExecutor.get(identify);
if (threadPoolExecutor != null) { if (threadPoolExecutor != null) {
BlockingQueue<Runnable> blockingQueue = threadPoolExecutor.getQueue();
result.setThreadPoolKey(identify); result.setThreadPoolKey(identify);
result.setCoreSize(threadPoolExecutor.getCorePoolSize()); result.setCoreSize(threadPoolExecutor.getCorePoolSize());
result.setMaximumSize(threadPoolExecutor.getMaximumPoolSize()); result.setMaximumSize(threadPoolExecutor.getMaximumPoolSize());
result.setBlockingQueueCapacity(blockingQueue.size() + blockingQueue.remainingCapacity());
return result; return result;
} }
log.warn("[{}] Hystrix thread pool not found.", identify); log.warn("[{}] Hystrix thread pool not found.", identify);

Loading…
Cancel
Save