public class org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker extends org.apache.dubbo.rpc.cluster.support.AbstractClusterInvoker
{
private static final org.apache.dubbo.common.logger.Logger logger;
private static final java.lang.String PREFER_REGISTRY_WITH_ZONE_KEY;
private final org.apache.dubbo.rpc.cluster.LoadBalance loadBalanceAmongRegistries;
public void <init>(org.apache.dubbo.rpc.cluster.Directory)
{
org.apache.dubbo.rpc.cluster.Directory v;
org.apache.dubbo.common.extension.ExtensionLoader v;
org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker v;
java.lang.Object v;
v := @this: org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker;
v := @parameter: org.apache.dubbo.rpc.cluster.Directory;
specialinvoke v.<org.apache.dubbo.rpc.cluster.support.AbstractClusterInvoker: void <init>(org.apache.dubbo.rpc.cluster.Directory)>(v);
v = staticinvoke <org.apache.dubbo.common.extension.ExtensionLoader: org.apache.dubbo.common.extension.ExtensionLoader getExtensionLoader(java.lang.Class)>(class "Lorg/apache/dubbo/rpc/cluster/LoadBalance;");
v = virtualinvoke v.<org.apache.dubbo.common.extension.ExtensionLoader: java.lang.Object getExtension(java.lang.String)>("random");
v.<org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker: org.apache.dubbo.rpc.cluster.LoadBalance loadBalanceAmongRegistries> = v;
return;
}
public org.apache.dubbo.rpc.Result doInvoke(org.apache.dubbo.rpc.Invocation, java.util.List, org.apache.dubbo.rpc.cluster.LoadBalance) throws org.apache.dubbo.rpc.RpcException
{
java.lang.IllegalStateException v;
org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker v;
org.apache.dubbo.common.URL v, v;
java.util.stream.Collector v;
boolean v, v, v, v, v, v, v, v, v, v, v, v;
java.util.List v;
java.util.stream.Stream v, v;
org.apache.dubbo.rpc.cluster.LoadBalance v, v;
org.apache.dubbo.rpc.Invocation v;
org.apache.dubbo.rpc.Invoker v, v, v, v;
java.util.function.Function v;
java.lang.String v, v, v, v, v;
java.util.Iterator v, v, v;
org.apache.dubbo.rpc.Result v, v, v, v, v;
java.lang.Object v, v;
v := @this: org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker;
v := @parameter: org.apache.dubbo.rpc.Invocation;
v := @parameter: java.util.List;
v := @parameter: org.apache.dubbo.rpc.cluster.LoadBalance;
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = interfaceinvoke v.<org.apache.dubbo.rpc.cluster.ClusterInvoker: boolean isAvailable()>();
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.dubbo.rpc.cluster.ClusterInvoker: org.apache.dubbo.common.URL getRegistryUrl()>();
v = virtualinvoke v.<org.apache.dubbo.common.URL: boolean getParameter(java.lang.String,boolean)>("registry.preferred", 0);
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.dubbo.rpc.cluster.ClusterInvoker: org.apache.dubbo.rpc.Result invoke(org.apache.dubbo.rpc.Invocation)>(v);
return v;
label:
v = interfaceinvoke v.<org.apache.dubbo.rpc.Invocation: java.lang.String getAttachment(java.lang.String)>("registry_zone");
v = staticinvoke <org.apache.dubbo.common.utils.StringUtils: boolean isNotEmpty(java.lang.String)>(v);
if v == 0 goto label;
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = interfaceinvoke v.<org.apache.dubbo.rpc.cluster.ClusterInvoker: boolean isAvailable()>();
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.dubbo.rpc.cluster.ClusterInvoker: org.apache.dubbo.common.URL getRegistryUrl()>();
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String getParameter(java.lang.String)>("registry.zone");
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.dubbo.rpc.cluster.ClusterInvoker: org.apache.dubbo.rpc.Result invoke(org.apache.dubbo.rpc.Invocation)>(v);
return v;
label:
v = interfaceinvoke v.<org.apache.dubbo.rpc.Invocation: java.lang.String getAttachment(java.lang.String)>("registry_zone_force");
v = staticinvoke <org.apache.dubbo.common.utils.StringUtils: boolean isNotEmpty(java.lang.String)>(v);
if v == 0 goto label;
v = "true";
v = virtualinvoke v.<java.lang.String: boolean equalsIgnoreCase(java.lang.String)>(v);
if v == 0 goto label;
v = new java.lang.IllegalStateException;
v = interfaceinvoke v.<java.util.List: java.util.stream.Stream stream()>();
v = staticinvoke <org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker$lambda_doInvoke_0__133: java.util.function.Function bootstrap$()>();
v = interfaceinvoke v.<java.util.stream.Stream: java.util.stream.Stream map(java.util.function.Function)>(v);
v = staticinvoke <java.util.stream.Collectors: java.util.stream.Collector joining(java.lang.CharSequence)>(",");
v = interfaceinvoke v.<java.util.stream.Stream: java.lang.Object collect(java.util.stream.Collector)>(v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.Object)>(v, 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[])>("No registry instance in zone or no available providers in the registry, zone: \u, registries: \u0001");
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v.<org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker: org.apache.dubbo.rpc.cluster.LoadBalance loadBalanceAmongRegistries>;
v = virtualinvoke v.<org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker: org.apache.dubbo.rpc.Invoker select(org.apache.dubbo.rpc.cluster.LoadBalance,org.apache.dubbo.rpc.Invocation,java.util.List,java.util.List)>(v, v, v, null);
v = interfaceinvoke v.<org.apache.dubbo.rpc.Invoker: boolean isAvailable()>();
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.dubbo.rpc.Invoker: org.apache.dubbo.rpc.Result invoke(org.apache.dubbo.rpc.Invocation)>(v);
return v;
label:
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = interfaceinvoke v.<org.apache.dubbo.rpc.cluster.ClusterInvoker: boolean isAvailable()>();
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.dubbo.rpc.cluster.ClusterInvoker: org.apache.dubbo.rpc.Result invoke(org.apache.dubbo.rpc.Invocation)>(v);
return v;
label:
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(0);
v = interfaceinvoke v.<org.apache.dubbo.rpc.Invoker: org.apache.dubbo.rpc.Result invoke(org.apache.dubbo.rpc.Invocation)>(v);
return v;
}
protected java.util.List list(org.apache.dubbo.rpc.Invocation) throws org.apache.dubbo.rpc.RpcException
{
org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker v;
int[] v;
boolean v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
java.util.List v;
org.apache.dubbo.rpc.cluster.support.migration.MigrationRule v, v;
org.apache.dubbo.rpc.Invocation v;
java.util.concurrent.atomic.AtomicBoolean v;
org.apache.dubbo.rpc.Invoker v, v;
java.util.ArrayList v, v;
int v, v, v;
java.lang.String v, v, v;
java.lang.UnsupportedOperationException v;
java.util.Iterator v, v;
org.apache.dubbo.common.logger.Logger v, v, v, v, v, v, v, v;
org.apache.dubbo.rpc.cluster.support.migration.MigrationStep v, v;
java.lang.Object v;
v := @this: org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker;
v := @parameter: org.apache.dubbo.rpc.Invocation;
v = specialinvoke v.<org.apache.dubbo.rpc.cluster.support.AbstractClusterInvoker: java.util.List list(org.apache.dubbo.rpc.Invocation)>(v);
if null == v goto label;
v = interfaceinvoke v.<java.util.List: int size()>();
if v >= 2 goto label;
label:
return v;
label:
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = 0;
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = interfaceinvoke v.<org.apache.dubbo.rpc.cluster.support.migration.MigrationClusterInvoker: boolean isServiceInvoker()>();
if v == 0 goto label;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
label:
v = interfaceinvoke v.<org.apache.dubbo.rpc.cluster.support.migration.MigrationClusterInvoker: java.util.concurrent.atomic.AtomicBoolean invokersChanged()>();
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean compareAndSet(boolean,boolean)>(1, 0);
if v == 0 goto label;
v = 1;
goto label;
label:
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v == 0 goto label;
label:
return v;
label:
v = null;
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
if v != null goto label;
v = interfaceinvoke v.<org.apache.dubbo.rpc.cluster.support.migration.MigrationClusterInvoker: org.apache.dubbo.rpc.cluster.support.migration.MigrationRule getMigrationRule()>();
goto label;
label:
v = interfaceinvoke v.<org.apache.dubbo.rpc.cluster.support.migration.MigrationClusterInvoker: org.apache.dubbo.rpc.cluster.support.migration.MigrationRule getMigrationRule()>();
v = virtualinvoke v.<java.lang.Object: boolean equals(java.lang.Object)>(v);
if v != 0 goto label;
v = staticinvoke <org.apache.dubbo.rpc.cluster.support.migration.MigrationRule: org.apache.dubbo.rpc.cluster.support.migration.MigrationRule queryRule()>();
label:
v = virtualinvoke v.<org.apache.dubbo.rpc.cluster.support.migration.MigrationRule: org.apache.dubbo.rpc.cluster.support.migration.MigrationStep getStep()>();
v = <org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker$1: int[] $SwitchMap$org$apache$dubbo$rpc$cluster$support$migration$MigrationStep>;
v = virtualinvoke v.<org.apache.dubbo.rpc.cluster.support.migration.MigrationStep: int ordinal()>();
v = v[v];
tableswitch(v)
{
case 1: goto label;
case 2: goto label;
case 3: goto label;
default: goto label;
};
label:
specialinvoke v.<org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker: void clusterRefresh(boolean,java.util.List)>(v, v);
specialinvoke v.<org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker: void clusterDestroy(boolean,java.util.List,boolean)>(v, v, 1);
v = <org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker: org.apache.dubbo.common.logger.Logger logger>;
v = interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker: org.apache.dubbo.common.logger.Logger logger>;
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void debug(java.lang.String)>("step is FORCE_INTERFACE");
label:
return v;
label:
specialinvoke v.<org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker: void clusterRefresh(boolean,java.util.List)>(v, v);
specialinvoke v.<org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker: void clusterRefresh(boolean,java.util.List)>(v, v);
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
if v == 0 goto label;
v = specialinvoke v.<org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker: boolean shouldMigrate(boolean,java.util.List,java.util.List)>(v, v, v);
if v == 0 goto label;
v = <org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker: org.apache.dubbo.common.logger.Logger logger>;
v = interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker: org.apache.dubbo.common.logger.Logger logger>;
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void debug(java.lang.String)>("step is APPLICATION_FIRST shouldMigrate true get serviceInvokers");
label:
return v;
label:
v = <org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker: org.apache.dubbo.common.logger.Logger logger>;
v = interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker: org.apache.dubbo.common.logger.Logger logger>;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v == 0 goto label;
v = "serviceInvokers is empty";
goto label;
label:
v = "shouldMigrate false";
label:
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(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[])>("step is APPLICATION_FIRST \u get interfaceInvokers");
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void debug(java.lang.String)>(v);
label:
return v;
label:
specialinvoke v.<org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker: void clusterRefresh(boolean,java.util.List)>(v, v);
specialinvoke v.<org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker: void clusterDestroy(boolean,java.util.List,boolean)>(v, v, 1);
v = <org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker: org.apache.dubbo.common.logger.Logger logger>;
v = interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker: org.apache.dubbo.common.logger.Logger logger>;
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void debug(java.lang.String)>("step is FORCE_APPLICATION");
label:
return v;
label:
v = new java.lang.UnsupportedOperationException;
v = virtualinvoke v.<org.apache.dubbo.rpc.cluster.support.migration.MigrationRule: org.apache.dubbo.rpc.cluster.support.migration.MigrationStep getStep()>();
v = virtualinvoke v.<org.apache.dubbo.rpc.cluster.support.migration.MigrationStep: java.lang.String name()>();
specialinvoke v.<java.lang.UnsupportedOperationException: void <init>(java.lang.String)>(v);
throw v;
}
private boolean shouldMigrate(boolean, java.util.List, java.util.List)
{
org.apache.dubbo.common.extension.ExtensionLoader v;
org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker v;
java.util.stream.Collector v;
boolean v, v, v, v, v;
java.util.function.Predicate v, v;
java.util.Set v;
java.util.List v, v;
java.util.stream.Stream v, v, v;
java.lang.Object v;
v := @this: org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker;
v := @parameter: boolean;
v := @parameter: java.util.List;
v := @parameter: java.util.List;
v = staticinvoke <org.apache.dubbo.common.extension.ExtensionLoader: org.apache.dubbo.common.extension.ExtensionLoader getExtensionLoader(java.lang.Class)>(class "Lorg/apache/dubbo/rpc/cluster/support/migration/MigrationClusterComparator;");
v = virtualinvoke v.<org.apache.dubbo.common.extension.ExtensionLoader: java.util.Set getSupportedExtensionInstances()>();
if v == null goto label;
v = interfaceinvoke v.<java.util.Set: boolean isEmpty()>();
if v != 0 goto label;
v = interfaceinvoke v.<java.util.Set: java.util.stream.Stream stream()>();
v = staticinvoke <org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker$lambda_shouldMigrate_1__135: java.util.function.Predicate bootstrap$(java.util.List,java.util.List)>(v, v);
v = interfaceinvoke v.<java.util.stream.Stream: boolean allMatch(java.util.function.Predicate)>(v);
return v;
label:
v = interfaceinvoke v.<java.util.List: java.util.stream.Stream stream()>();
v = staticinvoke <org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker$lambda_shouldMigrate_2__134: java.util.function.Predicate bootstrap$()>();
v = interfaceinvoke v.<java.util.stream.Stream: java.util.stream.Stream filter(java.util.function.Predicate)>(v);
v = staticinvoke <java.util.stream.Collectors: java.util.stream.Collector toList()>();
v = interfaceinvoke v.<java.util.stream.Stream: java.lang.Object collect(java.util.stream.Collector)>(v);
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
private void clusterDestroy(boolean, java.util.List, boolean)
{
java.util.function.Consumer v;
java.util.List v;
org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker v;
boolean v, v;
v := @this: org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker;
v := @parameter: boolean;
v := @parameter: java.util.List;
v := @parameter: boolean;
if v == 0 goto label;
v = staticinvoke <org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker$lambda_clusterDestroy_3__136: java.util.function.Consumer bootstrap$(boolean)>(v);
interfaceinvoke v.<java.util.List: void forEach(java.util.function.Consumer)>(v);
label:
return;
}
private void clusterRefresh(boolean, java.util.List)
{
java.util.function.Consumer v;
java.util.List v;
org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker v;
boolean v;
v := @this: org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker;
v := @parameter: boolean;
v := @parameter: java.util.List;
if v == 0 goto label;
v = staticinvoke <org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker$lambda_clusterRefresh_4__137: java.util.function.Consumer bootstrap$()>();
interfaceinvoke v.<java.util.List: void forEach(java.util.function.Consumer)>(v);
label:
return;
}
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/rpc/cluster/support/registry/ZoneAwareClusterInvoker;");
<org.apache.dubbo.rpc.cluster.support.registry.ZoneAwareClusterInvoker: org.apache.dubbo.common.logger.Logger logger> = v;
return;
}
}