public class org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository extends java.lang.Object implements org.apache.dubbo.common.threadpool.manager.ExecutorRepository
{
private static final org.apache.dubbo.common.logger.Logger logger;
private int DEFAULT_SCHEDULER_SIZE;
private final java.util.concurrent.ExecutorService SHARED_EXECUTOR;
private org.apache.dubbo.common.threadpool.manager.Ring scheduledExecutors;
private java.util.concurrent.ScheduledExecutorService serviceExporterExecutor;
private java.util.concurrent.ScheduledExecutorService reconnectScheduledExecutor;
private java.util.concurrent.ConcurrentMap data;
public void <init>()
{
java.lang.Runtime v;
java.util.concurrent.ConcurrentHashMap v;
org.apache.dubbo.common.threadpool.manager.Ring v, v;
org.apache.dubbo.common.utils.NamedThreadFactory v, v, v;
int v, v, v;
java.util.concurrent.ScheduledExecutorService v, v;
org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository v;
java.util.concurrent.ExecutorService v;
v := @this: org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository;
specialinvoke v.<java.lang.Object: void <init>()>();
v = staticinvoke <java.lang.Runtime: java.lang.Runtime getRuntime()>();
v = virtualinvoke v.<java.lang.Runtime: int availableProcessors()>();
v.<org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository: int DEFAULT_SCHEDULER_SIZE> = v;
v = new org.apache.dubbo.common.utils.NamedThreadFactory;
specialinvoke v.<org.apache.dubbo.common.utils.NamedThreadFactory: void <init>(java.lang.String,boolean)>("DubboSharedHandler", 1);
v = staticinvoke <java.util.concurrent.Executors: java.util.concurrent.ExecutorService newCachedThreadPool(java.util.concurrent.ThreadFactory)>(v);
v.<org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository: java.util.concurrent.ExecutorService SHARED_EXECUTOR> = v;
v = new org.apache.dubbo.common.threadpool.manager.Ring;
specialinvoke v.<org.apache.dubbo.common.threadpool.manager.Ring: void <init>()>();
v.<org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository: org.apache.dubbo.common.threadpool.manager.Ring scheduledExecutors> = v;
v = new java.util.concurrent.ConcurrentHashMap;
specialinvoke v.<java.util.concurrent.ConcurrentHashMap: void <init>()>();
v.<org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository: java.util.concurrent.ConcurrentMap data> = v;
v = 0;
label:
v = v.<org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository: int DEFAULT_SCHEDULER_SIZE>;
if v >= v goto label;
v = new org.apache.dubbo.common.utils.NamedThreadFactory;
specialinvoke v.<org.apache.dubbo.common.utils.NamedThreadFactory: void <init>(java.lang.String)>("Dubbo-framework-scheduler");
v = staticinvoke <java.util.concurrent.Executors: java.util.concurrent.ScheduledExecutorService newSingleThreadScheduledExecutor(java.util.concurrent.ThreadFactory)>(v);
v = v.<org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository: org.apache.dubbo.common.threadpool.manager.Ring scheduledExecutors>;
virtualinvoke v.<org.apache.dubbo.common.threadpool.manager.Ring: void addItem(java.lang.Object)>(v);
v = v + 1;
goto label;
label:
v = new org.apache.dubbo.common.utils.NamedThreadFactory;
specialinvoke v.<org.apache.dubbo.common.utils.NamedThreadFactory: void <init>(java.lang.String)>("Dubbo-exporter-scheduler");
v = staticinvoke <java.util.concurrent.Executors: java.util.concurrent.ScheduledExecutorService newScheduledThreadPool(int,java.util.concurrent.ThreadFactory)>(1, v);
v.<org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository: java.util.concurrent.ScheduledExecutorService serviceExporterExecutor> = v;
return;
}
public synchronized java.util.concurrent.ExecutorService createExecutorIfAbsent(org.apache.dubbo.common.URL)
{
java.lang.Integer v;
java.util.function.Function v, v;
java.util.concurrent.ConcurrentMap v;
org.apache.dubbo.common.URL v;
int v;
java.lang.Object v, v;
java.lang.String v, v, v;
org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository v;
boolean v, v, v;
v := @this: org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository;
v := @parameter: org.apache.dubbo.common.URL;
v = v.<org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository: java.util.concurrent.ConcurrentMap data>;
v = <org.apache.dubbo.common.constants.CommonConstants: java.lang.String EXECUTOR_SERVICE_COMPONENT_KEY>;
v = staticinvoke <org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository$lambda_createExecutorIfAbsent_0__218: java.util.function.Function bootstrap$()>();
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object computeIfAbsent(java.lang.Object,java.util.function.Function)>(v, v);
v = "consumer";
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String getParameter(java.lang.String)>("side");
v = virtualinvoke v.<java.lang.String: boolean equalsIgnoreCase(java.lang.String)>(v);
if v == 0 goto label;
v = 2147483647;
goto label;
label:
v = virtualinvoke v.<org.apache.dubbo.common.URL: int getPort()>();
label:
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = staticinvoke <org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository$lambda_createExecutorIfAbsent_1__219: java.util.function.Function bootstrap$(org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository,org.apache.dubbo.common.URL)>(v, v);
v = interfaceinvoke v.<java.util.Map: java.lang.Object computeIfAbsent(java.lang.Object,java.util.function.Function)>(v, v);
v = interfaceinvoke v.<java.util.concurrent.ExecutorService: boolean isShutdown()>();
if v != 0 goto label;
v = interfaceinvoke v.<java.util.concurrent.ExecutorService: boolean isTerminated()>();
if v == 0 goto label;
label:
interfaceinvoke v.<java.util.Map: java.lang.Object remove(java.lang.Object)>(v);
v = specialinvoke v.<org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository: java.util.concurrent.ExecutorService createExecutor(org.apache.dubbo.common.URL)>(v);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
label:
return v;
}
public java.util.concurrent.ExecutorService getExecutor(org.apache.dubbo.common.URL)
{
java.lang.Integer v;
java.util.concurrent.ConcurrentMap v;
org.apache.dubbo.common.URL v;
int v;
java.lang.String v, v, v, v;
org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository v;
java.util.concurrent.ExecutorService v;
boolean v, v, v;
org.apache.dubbo.common.logger.Logger v, v;
java.lang.Object v, v;
v := @this: org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository;
v := @parameter: org.apache.dubbo.common.URL;
v = v.<org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository: java.util.concurrent.ConcurrentMap data>;
v = <org.apache.dubbo.common.constants.CommonConstants: java.lang.String EXECUTOR_SERVICE_COMPONENT_KEY>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
v = <org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository: org.apache.dubbo.common.logger.Logger logger>;
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void warn(java.lang.String)>("No available executors, this is not expected, framework should call createExecutorIfAbsent first before coming to here.");
return null;
label:
v = "consumer";
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String getParameter(java.lang.String)>("side");
v = virtualinvoke v.<java.lang.String: boolean equalsIgnoreCase(java.lang.String)>(v);
if v == 0 goto label;
v = 2147483647;
goto label;
label:
v = virtualinvoke v.<org.apache.dubbo.common.URL: int getPort()>();
label:
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
v = interfaceinvoke v.<java.util.concurrent.ExecutorService: boolean isShutdown()>();
if v != 0 goto label;
v = interfaceinvoke v.<java.util.concurrent.ExecutorService: boolean isTerminated()>();
if v == 0 goto label;
label:
interfaceinvoke v.<java.util.Map: java.lang.Object remove(java.lang.Object)>(v);
v = null;
v = <org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository: org.apache.dubbo.common.logger.Logger logger>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.dubbo.common.URL)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Executor for \u is shutdown.");
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void info(java.lang.String)>(v);
label:
if v != null goto label;
v = v.<org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository: java.util.concurrent.ExecutorService SHARED_EXECUTOR>;
return v;
label:
return v;
}
public void updateThreadpool(org.apache.dubbo.common.URL, java.util.concurrent.ExecutorService)
{
java.lang.Throwable v;
org.apache.dubbo.common.logger.Logger v;
org.apache.dubbo.common.URL v;
int v, v, v;
java.lang.String v;
org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository v;
java.util.concurrent.ExecutorService v;
boolean v, v, v;
v := @this: org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository;
v := @parameter: org.apache.dubbo.common.URL;
v := @parameter: java.util.concurrent.ExecutorService;
label:
v = virtualinvoke v.<org.apache.dubbo.common.URL: boolean hasParameter(java.lang.String)>("threads");
if v == 0 goto label;
v = v instanceof java.util.concurrent.ThreadPoolExecutor;
if v == 0 goto label;
v = interfaceinvoke v.<java.util.concurrent.ExecutorService: boolean isShutdown()>();
if v != 0 goto label;
v = virtualinvoke v.<org.apache.dubbo.common.URL: int getParameter(java.lang.String,int)>("threads", 0);
v = virtualinvoke v.<java.util.concurrent.ThreadPoolExecutor: int getMaximumPoolSize()>();
v = virtualinvoke v.<java.util.concurrent.ThreadPoolExecutor: int getCorePoolSize()>();
if v <= 0 goto label;
if v != v goto label;
if v == v goto label;
label:
if v >= v goto label;
virtualinvoke v.<java.util.concurrent.ThreadPoolExecutor: void setCorePoolSize(int)>(v);
if v != v goto label;
virtualinvoke v.<java.util.concurrent.ThreadPoolExecutor: void setMaximumPoolSize(int)>(v);
goto label;
label:
virtualinvoke v.<java.util.concurrent.ThreadPoolExecutor: void setMaximumPoolSize(int)>(v);
if v != v goto label;
virtualinvoke v.<java.util.concurrent.ThreadPoolExecutor: void setCorePoolSize(int)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository: org.apache.dubbo.common.logger.Logger logger>;
v = virtualinvoke v.<java.lang.Throwable: java.lang.String getMessage()>();
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void error(java.lang.String,java.lang.Throwable)>(v, v);
label:
return;
catch java.lang.Throwable from label to label with label;
}
public java.util.concurrent.ScheduledExecutorService nextScheduledExecutor()
{
java.lang.Object v;
org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository v;
org.apache.dubbo.common.threadpool.manager.Ring v;
v := @this: org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository;
v = v.<org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository: org.apache.dubbo.common.threadpool.manager.Ring scheduledExecutors>;
v = virtualinvoke v.<org.apache.dubbo.common.threadpool.manager.Ring: java.lang.Object pollItem()>();
return v;
}
public java.util.concurrent.ScheduledExecutorService getServiceExporterExecutor()
{
java.util.concurrent.ScheduledExecutorService v;
org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository v;
v := @this: org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository;
v = v.<org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository: java.util.concurrent.ScheduledExecutorService serviceExporterExecutor>;
return v;
}
public java.util.concurrent.ExecutorService getSharedExecutor()
{
org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository v;
java.util.concurrent.ExecutorService v;
v := @this: org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository;
v = v.<org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository: java.util.concurrent.ExecutorService SHARED_EXECUTOR>;
return v;
}
public void destroyAll()
{
java.util.function.Consumer v;
java.util.Collection v;
org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository v;
java.util.concurrent.ConcurrentMap v;
v := @this: org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository;
v = v.<org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository: java.util.concurrent.ConcurrentMap data>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.util.Collection values()>();
v = staticinvoke <org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository$lambda_destroyAll_3__220: java.util.function.Consumer bootstrap$()>();
interfaceinvoke v.<java.util.Collection: void forEach(java.util.function.Consumer)>(v);
return;
}
private java.util.concurrent.ExecutorService createExecutor(org.apache.dubbo.common.URL)
{
org.apache.dubbo.common.URL v;
org.apache.dubbo.common.extension.ExtensionLoader v;
java.util.concurrent.Executor v;
java.lang.Object v;
org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository v;
v := @this: org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository;
v := @parameter: org.apache.dubbo.common.URL;
v = staticinvoke <org.apache.dubbo.common.extension.ExtensionLoader: org.apache.dubbo.common.extension.ExtensionLoader getExtensionLoader(java.lang.Class)>(class "Lorg/apache/dubbo/common/threadpool/ThreadPool;");
v = virtualinvoke v.<org.apache.dubbo.common.extension.ExtensionLoader: java.lang.Object getAdaptiveExtension()>();
v = interfaceinvoke v.<org.apache.dubbo.common.threadpool.ThreadPool: java.util.concurrent.Executor getExecutor(org.apache.dubbo.common.URL)>(v);
return v;
}
static void <clinit>()
{
org.apache.dubbo.common.logger.Logger v;
v = staticinvoke <org.apache.dubbo.common.logger.LoggerFactory: org.apache.dubbo.common.logger.Logger getLogger(java.lang.Class)>(class "Lorg/apache/dubbo/common/threadpool/manager/DefaultExecutorRepository;");
<org.apache.dubbo.common.threadpool.manager.DefaultExecutorRepository: org.apache.dubbo.common.logger.Logger logger> = v;
return;
}
}