public class org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker extends org.apache.dubbo.rpc.protocol.AbstractInvoker
{
private final org.apache.dubbo.remoting.exchange.ExchangeClient[] clients;
private final org.apache.dubbo.common.utils.AtomicPositiveInteger index;
private final java.lang.String version;
private final java.util.concurrent.locks.ReentrantLock destroyLock;
private final java.util.Set invokers;
public void <init>(java.lang.Class, org.apache.dubbo.common.URL, org.apache.dubbo.remoting.exchange.ExchangeClient[])
{
org.apache.dubbo.common.URL v;
java.lang.Class v;
org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker v;
org.apache.dubbo.remoting.exchange.ExchangeClient[] v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker;
v := @parameter: java.lang.Class;
v := @parameter: org.apache.dubbo.common.URL;
v := @parameter: org.apache.dubbo.remoting.exchange.ExchangeClient[];
specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: void <init>(java.lang.Class,org.apache.dubbo.common.URL,org.apache.dubbo.remoting.exchange.ExchangeClient[],java.util.Set)>(v, v, v, null);
return;
}
public void <init>(java.lang.Class, org.apache.dubbo.common.URL, org.apache.dubbo.remoting.exchange.ExchangeClient[], java.util.Set)
{
java.util.concurrent.locks.ReentrantLock v;
org.apache.dubbo.common.utils.AtomicPositiveInteger v;
java.util.Set v;
java.lang.String[] v;
org.apache.dubbo.common.URL v;
java.lang.Class v;
java.lang.String v;
org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker v;
org.apache.dubbo.remoting.exchange.ExchangeClient[] v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker;
v := @parameter: java.lang.Class;
v := @parameter: org.apache.dubbo.common.URL;
v := @parameter: org.apache.dubbo.remoting.exchange.ExchangeClient[];
v := @parameter: java.util.Set;
v = newarray (java.lang.String)[3];
v[0] = "interface";
v[1] = "group";
v[2] = "token";
specialinvoke v.<org.apache.dubbo.rpc.protocol.AbstractInvoker: void <init>(java.lang.Class,org.apache.dubbo.common.URL,java.lang.String[])>(v, v, v);
v = new org.apache.dubbo.common.utils.AtomicPositiveInteger;
specialinvoke v.<org.apache.dubbo.common.utils.AtomicPositiveInteger: void <init>()>();
v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: org.apache.dubbo.common.utils.AtomicPositiveInteger index> = v;
v = new java.util.concurrent.locks.ReentrantLock;
specialinvoke v.<java.util.concurrent.locks.ReentrantLock: void <init>()>();
v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: java.util.concurrent.locks.ReentrantLock destroyLock> = v;
v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: org.apache.dubbo.remoting.exchange.ExchangeClient[] clients> = v;
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String getParameter(java.lang.String,java.lang.String)>("version", "0.0.0");
v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: java.lang.String version> = v;
v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: java.util.Set invokers> = v;
return;
}
protected org.apache.dubbo.rpc.Result doInvoke(org.apache.dubbo.rpc.Invocation) throws java.lang.Throwable
{
org.apache.dubbo.remoting.RemotingException v;
org.apache.dubbo.remoting.exchange.ExchangeClient v;
java.lang.Integer v;
org.apache.dubbo.common.URL v, v, v, v, v, v;
org.apache.dubbo.remoting.exchange.ExchangeClient[] v, v, v, v;
boolean v, v;
org.apache.dubbo.rpc.AsyncRpcResult v, v;
org.apache.dubbo.rpc.RpcException v, v;
org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker v;
org.apache.dubbo.common.utils.AtomicPositiveInteger v;
org.apache.dubbo.rpc.Invocation v;
java.util.concurrent.CompletableFuture v, v;
java.util.function.Function v;
int v, v, v, v, v;
java.lang.String v, v, v, v, v, v, v, v, v;
java.util.concurrent.ExecutorService v;
org.apache.dubbo.rpc.FutureContext v;
org.apache.dubbo.remoting.TimeoutException v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker;
v := @parameter: org.apache.dubbo.rpc.Invocation;
v = staticinvoke <org.apache.dubbo.rpc.support.RpcUtils: java.lang.String getMethodName(org.apache.dubbo.rpc.Invocation)>(v);
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: org.apache.dubbo.common.URL getUrl()>();
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String getPath()>();
virtualinvoke v.<org.apache.dubbo.rpc.RpcInvocation: void setAttachment(java.lang.String,java.lang.String)>("path", v);
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: java.lang.String version>;
virtualinvoke v.<org.apache.dubbo.rpc.RpcInvocation: void setAttachment(java.lang.String,java.lang.String)>("version", v);
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: org.apache.dubbo.remoting.exchange.ExchangeClient[] clients>;
v = lengthof v;
if v != 1 goto label;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: org.apache.dubbo.remoting.exchange.ExchangeClient[] clients>;
v = v[0];
goto label;
label:
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: org.apache.dubbo.remoting.exchange.ExchangeClient[] clients>;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: org.apache.dubbo.common.utils.AtomicPositiveInteger index>;
v = virtualinvoke v.<org.apache.dubbo.common.utils.AtomicPositiveInteger: int getAndIncrement()>();
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: org.apache.dubbo.remoting.exchange.ExchangeClient[] clients>;
v = lengthof v;
v = v % v;
v = v[v];
label:
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: org.apache.dubbo.common.URL getUrl()>();
v = staticinvoke <org.apache.dubbo.rpc.support.RpcUtils: boolean isOneway(org.apache.dubbo.common.URL,org.apache.dubbo.rpc.Invocation)>(v, v);
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: int calculateTimeout(org.apache.dubbo.rpc.Invocation,java.lang.String)>(v, v);
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<org.apache.dubbo.rpc.Invocation: java.lang.Object put(java.lang.Object,java.lang.Object)>("timeout", v);
if v == 0 goto label;
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: org.apache.dubbo.common.URL getUrl()>();
v = virtualinvoke v.<org.apache.dubbo.common.URL: boolean getMethodParameter(java.lang.String,java.lang.String,boolean)>(v, "sent", 0);
interfaceinvoke v.<org.apache.dubbo.remoting.exchange.ExchangeClient: void send(java.lang.Object,boolean)>(v, v);
v = staticinvoke <org.apache.dubbo.rpc.AsyncRpcResult: org.apache.dubbo.rpc.AsyncRpcResult newDefaultAsyncResult(org.apache.dubbo.rpc.Invocation)>(v);
label:
return v;
label:
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: org.apache.dubbo.common.URL getUrl()>();
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: java.util.concurrent.ExecutorService getCallbackExecutor(org.apache.dubbo.common.URL,org.apache.dubbo.rpc.Invocation)>(v, v);
v = interfaceinvoke v.<org.apache.dubbo.remoting.exchange.ExchangeClient: java.util.concurrent.CompletableFuture request(java.lang.Object,int,java.util.concurrent.ExecutorService)>(v, v, v);
v = staticinvoke <org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker$lambda_doInvoke_0__415: java.util.function.Function bootstrap$()>();
v = virtualinvoke v.<java.util.concurrent.CompletableFuture: java.util.concurrent.CompletableFuture thenApply(java.util.function.Function)>(v);
v = staticinvoke <org.apache.dubbo.rpc.FutureContext: org.apache.dubbo.rpc.FutureContext getContext()>();
virtualinvoke v.<org.apache.dubbo.rpc.FutureContext: void setCompatibleFuture(java.util.concurrent.CompletableFuture)>(v);
v = new org.apache.dubbo.rpc.AsyncRpcResult;
specialinvoke v.<org.apache.dubbo.rpc.AsyncRpcResult: void <init>(java.util.concurrent.CompletableFuture,org.apache.dubbo.rpc.Invocation)>(v, v);
virtualinvoke v.<org.apache.dubbo.rpc.AsyncRpcResult: void setExecutor(java.util.concurrent.Executor)>(v);
label:
return v;
label:
v := @caughtexception;
v = new org.apache.dubbo.rpc.RpcException;
v = interfaceinvoke v.<org.apache.dubbo.rpc.Invocation: java.lang.String getMethodName()>();
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: org.apache.dubbo.common.URL getUrl()>();
v = virtualinvoke v.<org.apache.dubbo.remoting.TimeoutException: java.lang.String getMessage()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,org.apache.dubbo.common.URL,java.lang.String)>(v, 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[])>("Invoke remote method timeout. method: \u, provider: \u, cause: \u0001");
specialinvoke v.<org.apache.dubbo.rpc.RpcException: void <init>(int,java.lang.String,java.lang.Throwable)>(2, v, v);
throw v;
label:
v := @caughtexception;
v = new org.apache.dubbo.rpc.RpcException;
v = interfaceinvoke v.<org.apache.dubbo.rpc.Invocation: java.lang.String getMethodName()>();
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: org.apache.dubbo.common.URL getUrl()>();
v = virtualinvoke v.<org.apache.dubbo.remoting.RemotingException: java.lang.String getMessage()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,org.apache.dubbo.common.URL,java.lang.String)>(v, 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[])>("Failed to invoke remote method: \u, provider: \u, cause: \u0001");
specialinvoke v.<org.apache.dubbo.rpc.RpcException: void <init>(int,java.lang.String,java.lang.Throwable)>(1, v, v);
throw v;
catch org.apache.dubbo.remoting.TimeoutException from label to label with label;
catch org.apache.dubbo.remoting.TimeoutException from label to label with label;
catch org.apache.dubbo.remoting.RemotingException from label to label with label;
catch org.apache.dubbo.remoting.RemotingException from label to label with label;
}
public boolean isAvailable()
{
org.apache.dubbo.remoting.exchange.ExchangeClient v;
int v, v;
org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker v;
org.apache.dubbo.remoting.exchange.ExchangeClient[] v;
boolean v, v, v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker;
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.AbstractInvoker: boolean isAvailable()>();
if v != 0 goto label;
return 0;
label:
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: org.apache.dubbo.remoting.exchange.ExchangeClient[] clients>;
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = interfaceinvoke v.<org.apache.dubbo.remoting.exchange.ExchangeClient: boolean isConnected()>();
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.dubbo.remoting.exchange.ExchangeClient: boolean hasAttribute(java.lang.String)>("channel.readonly");
if v != 0 goto label;
return 1;
label:
v = v + 1;
goto label;
label:
return 0;
}
public void destroy()
{
java.lang.Throwable v, v;
org.apache.dubbo.remoting.exchange.ExchangeClient v;
int v, v, v;
java.lang.String v;
org.apache.dubbo.remoting.exchange.ExchangeClient[] v;
boolean v, v;
java.util.concurrent.locks.ReentrantLock v, v, v, v;
org.apache.dubbo.common.logger.Logger v;
java.util.Set v, v;
org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker;
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.AbstractInvoker: boolean isDestroyed()>();
if v == 0 goto label;
return;
label:
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: java.util.concurrent.locks.ReentrantLock destroyLock>;
virtualinvoke v.<java.util.concurrent.locks.ReentrantLock: void lock()>();
label:
v = specialinvoke v.<org.apache.dubbo.rpc.protocol.AbstractInvoker: boolean isDestroyed()>();
if v == 0 goto label;
label:
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: java.util.concurrent.locks.ReentrantLock destroyLock>;
virtualinvoke v.<java.util.concurrent.locks.ReentrantLock: void unlock()>();
return;
label:
specialinvoke v.<org.apache.dubbo.rpc.protocol.AbstractInvoker: void destroy()>();
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: java.util.Set invokers>;
if v == null goto label;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: java.util.Set invokers>;
interfaceinvoke v.<java.util.Set: boolean remove(java.lang.Object)>(v);
label:
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: org.apache.dubbo.remoting.exchange.ExchangeClient[] clients>;
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
label:
v = staticinvoke <org.apache.dubbo.common.config.ConfigurationUtils: int getServerShutdownTimeout()>();
interfaceinvoke v.<org.apache.dubbo.remoting.exchange.ExchangeClient: void close(int)>(v);
label:
goto label;
label:
v := @caughtexception;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: 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 warn(java.lang.String,java.lang.Throwable)>(v, v);
label:
v = v + 1;
goto label;
label:
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: java.util.concurrent.locks.ReentrantLock destroyLock>;
virtualinvoke v.<java.util.concurrent.locks.ReentrantLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: java.util.concurrent.locks.ReentrantLock destroyLock>;
virtualinvoke v.<java.util.concurrent.locks.ReentrantLock: void unlock()>();
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private int calculateTimeout(org.apache.dubbo.rpc.Invocation, java.lang.String)
{
org.apache.dubbo.rpc.RpcContext v, v;
org.apache.dubbo.rpc.Invocation v;
long v;
java.lang.Integer v, v;
java.util.concurrent.TimeUnit v;
org.apache.dubbo.common.URL v, v;
java.lang.Object v;
java.lang.String v;
org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker v;
boolean v;
v := @this: org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker;
v := @parameter: org.apache.dubbo.rpc.Invocation;
v := @parameter: java.lang.String;
v = staticinvoke <org.apache.dubbo.rpc.RpcContext: org.apache.dubbo.rpc.RpcContext getContext()>();
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcContext: java.lang.Object get(java.lang.String)>("timeout-countdown");
if v != null goto label;
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: org.apache.dubbo.common.URL getUrl()>();
v = staticinvoke <org.apache.dubbo.rpc.RpcContext: org.apache.dubbo.rpc.RpcContext getContext()>();
v = staticinvoke <org.apache.dubbo.rpc.support.RpcUtils: long getTimeout(org.apache.dubbo.common.URL,java.lang.String,org.apache.dubbo.rpc.RpcContext,long)>(v, v, v, 1000L);
v = virtualinvoke v.<org.apache.dubbo.rpc.protocol.dubbo.DubboInvoker: org.apache.dubbo.common.URL getUrl()>();
v = virtualinvoke v.<org.apache.dubbo.common.URL: boolean getParameter(java.lang.String,boolean)>("enable-timeout-countdown", 0);
if v == 0 goto label;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<org.apache.dubbo.rpc.Invocation: void setObjectAttachment(java.lang.String,java.lang.Object)>("_TO", v);
goto label;
label:
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit MILLISECONDS>;
virtualinvoke v.<org.apache.dubbo.rpc.TimeoutCountDown: long timeRemaining(java.util.concurrent.TimeUnit)>(v);
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<org.apache.dubbo.rpc.Invocation: void setObjectAttachment(java.lang.String,java.lang.Object)>("_TO", v);
label:
return v;
}
}