public class org.apache.dubbo.rpc.cluster.support.BroadcastClusterInvoker extends org.apache.dubbo.rpc.cluster.support.AbstractClusterInvoker
{
private static final org.apache.dubbo.common.logger.Logger logger;
private static final java.lang.String BROADCAST_FAIL_PERCENT_KEY;
private static final int MAX_BROADCAST_FAIL_PERCENT;
private static final int MIN_BROADCAST_FAIL_PERCENT;
public void <init>(org.apache.dubbo.rpc.cluster.Directory)
{
org.apache.dubbo.rpc.cluster.Directory v;
org.apache.dubbo.rpc.cluster.support.BroadcastClusterInvoker v;
v := @this: org.apache.dubbo.rpc.cluster.support.BroadcastClusterInvoker;
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);
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.Integer v, v, v;
org.apache.dubbo.common.URL v;
boolean v, v;
org.apache.dubbo.rpc.RpcException v;
java.util.List v;
java.lang.Throwable v, v, v;
java.lang.Object[] v, v, v;
org.apache.dubbo.rpc.cluster.LoadBalance v;
org.apache.dubbo.rpc.RpcContext v;
org.apache.dubbo.rpc.Invocation v;
int v, v, v, v, v;
java.lang.String v, v, v, v, v;
java.util.Iterator v;
org.apache.dubbo.common.logger.Logger v, v, v, v, v;
org.apache.dubbo.rpc.Result v;
org.apache.dubbo.rpc.cluster.support.BroadcastClusterInvoker v;
java.lang.Object v;
v := @this: org.apache.dubbo.rpc.cluster.support.BroadcastClusterInvoker;
v := @parameter: org.apache.dubbo.rpc.Invocation;
v := @parameter: java.util.List;
v := @parameter: org.apache.dubbo.rpc.cluster.LoadBalance;
virtualinvoke v.<org.apache.dubbo.rpc.cluster.support.BroadcastClusterInvoker: void checkInvokers(java.util.List,org.apache.dubbo.rpc.Invocation)>(v, v);
v = staticinvoke <org.apache.dubbo.rpc.RpcContext: org.apache.dubbo.rpc.RpcContext getContext()>();
virtualinvoke v.<org.apache.dubbo.rpc.RpcContext: org.apache.dubbo.rpc.RpcContext setInvokers(java.util.List)>(v);
v = null;
v = null;
v = virtualinvoke v.<org.apache.dubbo.rpc.cluster.support.BroadcastClusterInvoker: org.apache.dubbo.common.URL getUrl()>();
v = virtualinvoke v.<org.apache.dubbo.common.URL: int getParameter(java.lang.String,int)>("broadcast.fail.percent", 100);
if v < 0 goto label;
if v <= 100 goto label;
label:
v = <org.apache.dubbo.rpc.cluster.support.BroadcastClusterInvoker: org.apache.dubbo.common.logger.Logger logger>;
v = newarray (java.lang.Object)[1];
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[0] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("The value corresponding to the broadcast.fail.percent parameter must be between 0 and 100. The current setting is %s, which is reset to 100.", v);
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void info(java.lang.String)>(v);
v = 100;
label:
v = interfaceinvoke v.<java.util.List: int size()>();
v = v * v;
v = v / 100;
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()>();
label:
v = interfaceinvoke v.<org.apache.dubbo.rpc.Invoker: org.apache.dubbo.rpc.Result invoke(org.apache.dubbo.rpc.Invocation)>(v);
if null == v goto label;
v = interfaceinvoke v.<org.apache.dubbo.rpc.Result: boolean hasException()>();
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.dubbo.rpc.Result: java.lang.Throwable getException()>();
if null == v goto label;
v = interfaceinvoke v.<org.apache.dubbo.rpc.Result: java.lang.Throwable getException()>();
v = specialinvoke v.<org.apache.dubbo.rpc.cluster.support.BroadcastClusterInvoker: org.apache.dubbo.rpc.RpcException getRpcException(java.lang.Throwable)>(v);
v = <org.apache.dubbo.rpc.cluster.support.BroadcastClusterInvoker: org.apache.dubbo.common.logger.Logger logger>;
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcException: java.lang.String getMessage()>();
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void warn(java.lang.String,java.lang.Throwable)>(v, v);
if v == v goto label;
label:
v = v + 1;
label:
goto label;
label:
v := @caughtexception;
v = specialinvoke v.<org.apache.dubbo.rpc.cluster.support.BroadcastClusterInvoker: org.apache.dubbo.rpc.RpcException getRpcException(java.lang.Throwable)>(v);
v = <org.apache.dubbo.rpc.cluster.support.BroadcastClusterInvoker: org.apache.dubbo.common.logger.Logger logger>;
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcException: java.lang.String getMessage()>();
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void warn(java.lang.String,java.lang.Throwable)>(v, v);
if v == v goto label;
v = v + 1;
goto label;
label:
if v == null goto label;
if v != v goto label;
v = <org.apache.dubbo.rpc.cluster.support.BroadcastClusterInvoker: org.apache.dubbo.common.logger.Logger logger>;
v = newarray (java.lang.Object)[1];
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[0] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("The number of BroadcastCluster call failures has reached the threshold %s", v);
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void debug(java.lang.String)>(v);
goto label;
label:
v = <org.apache.dubbo.rpc.cluster.support.BroadcastClusterInvoker: org.apache.dubbo.common.logger.Logger logger>;
v = newarray (java.lang.Object)[1];
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[0] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("The number of BroadcastCluster call failures has not reached the threshold %s, fail size is %s", v);
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void debug(java.lang.String)>(v);
label:
throw v;
label:
return v;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private org.apache.dubbo.rpc.RpcException getRpcException(java.lang.Throwable)
{
java.lang.Throwable v;
org.apache.dubbo.rpc.cluster.support.BroadcastClusterInvoker v;
java.lang.String v;
org.apache.dubbo.rpc.RpcException v;
boolean v;
v := @this: org.apache.dubbo.rpc.cluster.support.BroadcastClusterInvoker;
v := @parameter: java.lang.Throwable;
v = v instanceof org.apache.dubbo.rpc.RpcException;
if v != 0 goto label;
v = new org.apache.dubbo.rpc.RpcException;
v = virtualinvoke v.<java.lang.Throwable: java.lang.String getMessage()>();
specialinvoke v.<org.apache.dubbo.rpc.RpcException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
v = v;
label:
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/rpc/cluster/support/BroadcastClusterInvoker;");
<org.apache.dubbo.rpc.cluster.support.BroadcastClusterInvoker: org.apache.dubbo.common.logger.Logger logger> = v;
return;
}
}