public abstract class org.apache.dubbo.remoting.transport.AbstractClient extends org.apache.dubbo.remoting.transport.AbstractEndpoint implements org.apache.dubbo.remoting.Client
{
protected static final java.lang.String CLIENT_THREAD_POOL_NAME;
private static final org.apache.dubbo.common.logger.Logger logger;
private final java.util.concurrent.locks.Lock connectLock;
private final boolean needReconnect;
protected volatile java.util.concurrent.ExecutorService executor;
private org.apache.dubbo.common.threadpool.manager.ExecutorRepository executorRepository;
public void <init>(org.apache.dubbo.common.URL, org.apache.dubbo.remoting.ChannelHandler) throws org.apache.dubbo.remoting.RemotingException
{
org.apache.dubbo.remoting.ChannelHandler v;
org.apache.dubbo.remoting.RemotingException v, v, v;
java.net.InetAddress v, v, v, v;
org.apache.dubbo.common.URL v;
boolean v, v, v;
java.net.InetSocketAddress v, v, v, v, v, v;
java.lang.Throwable v, v;
org.apache.dubbo.common.extension.ExtensionLoader v;
org.apache.dubbo.remoting.transport.AbstractClient v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v;
java.util.concurrent.locks.ReentrantLock v;
org.apache.dubbo.common.logger.Logger v, v, v;
java.lang.Class v, v, v, v;
java.lang.Object v;
v := @this: org.apache.dubbo.remoting.transport.AbstractClient;
v := @parameter: org.apache.dubbo.common.URL;
v := @parameter: org.apache.dubbo.remoting.ChannelHandler;
specialinvoke v.<org.apache.dubbo.remoting.transport.AbstractEndpoint: void <init>(org.apache.dubbo.common.URL,org.apache.dubbo.remoting.ChannelHandler)>(v, v);
v = new java.util.concurrent.locks.ReentrantLock;
specialinvoke v.<java.util.concurrent.locks.ReentrantLock: void <init>()>();
v.<org.apache.dubbo.remoting.transport.AbstractClient: java.util.concurrent.locks.Lock connectLock> = v;
v = staticinvoke <org.apache.dubbo.common.extension.ExtensionLoader: org.apache.dubbo.common.extension.ExtensionLoader getExtensionLoader(java.lang.Class)>(class "Lorg/apache/dubbo/common/threadpool/manager/ExecutorRepository;");
v = virtualinvoke v.<org.apache.dubbo.common.extension.ExtensionLoader: java.lang.Object getDefaultExtension()>();
v.<org.apache.dubbo.remoting.transport.AbstractClient: org.apache.dubbo.common.threadpool.manager.ExecutorRepository executorRepository> = v;
v = virtualinvoke v.<org.apache.dubbo.common.URL: boolean getParameter(java.lang.String,boolean)>("send.reconnect", 0);
v.<org.apache.dubbo.remoting.transport.AbstractClient: boolean needReconnect> = v;
specialinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: void initExecutor(org.apache.dubbo.common.URL)>(v);
label:
virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: void doOpen()>();
label:
goto label;
label:
v := @caughtexception;
virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: void close()>();
v = new org.apache.dubbo.remoting.RemotingException;
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.net.InetSocketAddress toInetSocketAddress()>();
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getSimpleName()>();
v = staticinvoke <org.apache.dubbo.common.utils.NetUtils: java.net.InetAddress getLocalAddress()>();
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: java.net.InetSocketAddress getRemoteAddress()>();
v = virtualinvoke v.<java.lang.Throwable: java.lang.String getMessage()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.net.InetAddress,java.net.InetSocketAddress,java.lang.String)>(v, 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 start \u \u connect to the server \u, cause: \u0001");
specialinvoke v.<org.apache.dubbo.remoting.RemotingException: void <init>(java.net.InetSocketAddress,java.net.InetSocketAddress,java.lang.String,java.lang.Throwable)>(v, null, v, v);
throw v;
label:
virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: void connect()>();
v = <org.apache.dubbo.remoting.transport.AbstractClient: org.apache.dubbo.common.logger.Logger logger>;
v = interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: boolean isInfoEnabled()>();
if v == 0 goto label;
v = <org.apache.dubbo.remoting.transport.AbstractClient: org.apache.dubbo.common.logger.Logger logger>;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getSimpleName()>();
v = staticinvoke <org.apache.dubbo.common.utils.NetUtils: java.net.InetAddress getLocalAddress()>();
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: java.net.InetSocketAddress getRemoteAddress()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.net.InetAddress,java.net.InetSocketAddress)>(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[])>("Start \u \u connect to the server \u0001");
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void info(java.lang.String)>(v);
label:
goto label;
label:
v := @caughtexception;
v = virtualinvoke v.<org.apache.dubbo.common.URL: boolean getParameter(java.lang.String,boolean)>("check", 1);
if v == 0 goto label;
virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: void close()>();
throw v;
label:
v = <org.apache.dubbo.remoting.transport.AbstractClient: org.apache.dubbo.common.logger.Logger logger>;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getSimpleName()>();
v = staticinvoke <org.apache.dubbo.common.utils.NetUtils: java.net.InetAddress getLocalAddress()>();
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: java.net.InetSocketAddress getRemoteAddress()>();
v = virtualinvoke v.<org.apache.dubbo.remoting.RemotingException: java.lang.String getMessage()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.net.InetAddress,java.net.InetSocketAddress,java.lang.String)>(v, 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 start \u \u connect to the server \u (check == false, ignore and retry later!), cause: \u0001");
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void warn(java.lang.String,java.lang.Throwable)>(v, v);
goto label;
label:
v := @caughtexception;
virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: void close()>();
v = new org.apache.dubbo.remoting.RemotingException;
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.net.InetSocketAddress toInetSocketAddress()>();
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getSimpleName()>();
v = staticinvoke <org.apache.dubbo.common.utils.NetUtils: java.net.InetAddress getLocalAddress()>();
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: java.net.InetSocketAddress getRemoteAddress()>();
v = virtualinvoke v.<java.lang.Throwable: java.lang.String getMessage()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.net.InetAddress,java.net.InetSocketAddress,java.lang.String)>(v, 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 start \u \u connect to the server \u, cause: \u0001");
specialinvoke v.<org.apache.dubbo.remoting.RemotingException: void <init>(java.net.InetSocketAddress,java.net.InetSocketAddress,java.lang.String,java.lang.Throwable)>(v, null, v, v);
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
catch org.apache.dubbo.remoting.RemotingException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private void initExecutor(org.apache.dubbo.common.URL)
{
org.apache.dubbo.common.URL v, v, v;
org.apache.dubbo.remoting.transport.AbstractClient v;
org.apache.dubbo.common.threadpool.manager.ExecutorRepository v;
java.util.concurrent.ExecutorService v;
v := @this: org.apache.dubbo.remoting.transport.AbstractClient;
v := @parameter: org.apache.dubbo.common.URL;
v = virtualinvoke v.<org.apache.dubbo.common.URL: org.apache.dubbo.common.URL addParameter(java.lang.String,java.lang.String)>("threadname", "DubboClientHandler");
v = virtualinvoke v.<org.apache.dubbo.common.URL: org.apache.dubbo.common.URL addParameterIfAbsent(java.lang.String,java.lang.String)>("threadpool", "cached");
v = v.<org.apache.dubbo.remoting.transport.AbstractClient: org.apache.dubbo.common.threadpool.manager.ExecutorRepository executorRepository>;
v = interfaceinvoke v.<org.apache.dubbo.common.threadpool.manager.ExecutorRepository: java.util.concurrent.ExecutorService createExecutorIfAbsent(org.apache.dubbo.common.URL)>(v);
v.<org.apache.dubbo.remoting.transport.AbstractClient: java.util.concurrent.ExecutorService executor> = v;
return;
}
protected static org.apache.dubbo.remoting.ChannelHandler wrapChannelHandler(org.apache.dubbo.common.URL, org.apache.dubbo.remoting.ChannelHandler)
{
org.apache.dubbo.remoting.ChannelHandler v, v;
org.apache.dubbo.common.URL v;
v := @parameter: org.apache.dubbo.common.URL;
v := @parameter: org.apache.dubbo.remoting.ChannelHandler;
v = staticinvoke <org.apache.dubbo.remoting.transport.dispatcher.ChannelHandlers: org.apache.dubbo.remoting.ChannelHandler wrap(org.apache.dubbo.remoting.ChannelHandler,org.apache.dubbo.common.URL)>(v, v);
return v;
}
public java.net.InetSocketAddress getConnectAddress()
{
org.apache.dubbo.common.URL v, v;
org.apache.dubbo.remoting.transport.AbstractClient v;
int v;
java.lang.String v, v;
java.net.InetSocketAddress v;
v := @this: org.apache.dubbo.remoting.transport.AbstractClient;
v = new java.net.InetSocketAddress;
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: org.apache.dubbo.common.URL getUrl()>();
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String getHost()>();
v = staticinvoke <org.apache.dubbo.common.utils.NetUtils: java.lang.String filterLocalHost(java.lang.String)>(v);
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: org.apache.dubbo.common.URL getUrl()>();
v = virtualinvoke v.<org.apache.dubbo.common.URL: int getPort()>();
specialinvoke v.<java.net.InetSocketAddress: void <init>(java.lang.String,int)>(v, v);
return v;
}
public java.net.InetSocketAddress getRemoteAddress()
{
org.apache.dubbo.common.URL v;
org.apache.dubbo.remoting.transport.AbstractClient v;
java.net.InetSocketAddress v, v;
org.apache.dubbo.remoting.Channel v;
v := @this: org.apache.dubbo.remoting.transport.AbstractClient;
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: org.apache.dubbo.remoting.Channel getChannel()>();
if v != null goto label;
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: org.apache.dubbo.common.URL getUrl()>();
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.net.InetSocketAddress toInetSocketAddress()>();
return v;
label:
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: java.net.InetSocketAddress getRemoteAddress()>();
return v;
}
public java.net.InetSocketAddress getLocalAddress()
{
org.apache.dubbo.remoting.transport.AbstractClient v;
java.lang.String v;
java.net.InetSocketAddress v, v;
org.apache.dubbo.remoting.Channel v;
v := @this: org.apache.dubbo.remoting.transport.AbstractClient;
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: org.apache.dubbo.remoting.Channel getChannel()>();
if v != null goto label;
v = staticinvoke <org.apache.dubbo.common.utils.NetUtils: java.lang.String getLocalHost()>();
v = staticinvoke <java.net.InetSocketAddress: java.net.InetSocketAddress createUnresolved(java.lang.String,int)>(v, 0);
return v;
label:
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: java.net.InetSocketAddress getLocalAddress()>();
return v;
}
public boolean isConnected()
{
org.apache.dubbo.remoting.transport.AbstractClient v;
org.apache.dubbo.remoting.Channel v;
boolean v;
v := @this: org.apache.dubbo.remoting.transport.AbstractClient;
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: org.apache.dubbo.remoting.Channel getChannel()>();
if v != null goto label;
return 0;
label:
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: boolean isConnected()>();
return v;
}
public java.lang.Object getAttribute(java.lang.String)
{
org.apache.dubbo.remoting.transport.AbstractClient v;
java.lang.Object v;
java.lang.String v;
org.apache.dubbo.remoting.Channel v;
v := @this: org.apache.dubbo.remoting.transport.AbstractClient;
v := @parameter: java.lang.String;
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: org.apache.dubbo.remoting.Channel getChannel()>();
if v != null goto label;
return null;
label:
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: java.lang.Object getAttribute(java.lang.String)>(v);
return v;
}
public void setAttribute(java.lang.String, java.lang.Object)
{
org.apache.dubbo.remoting.transport.AbstractClient v;
java.lang.Object v;
java.lang.String v;
org.apache.dubbo.remoting.Channel v;
v := @this: org.apache.dubbo.remoting.transport.AbstractClient;
v := @parameter: java.lang.String;
v := @parameter: java.lang.Object;
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: org.apache.dubbo.remoting.Channel getChannel()>();
if v != null goto label;
return;
label:
interfaceinvoke v.<org.apache.dubbo.remoting.Channel: void setAttribute(java.lang.String,java.lang.Object)>(v, v);
return;
}
public void removeAttribute(java.lang.String)
{
java.lang.String v;
org.apache.dubbo.remoting.transport.AbstractClient v;
org.apache.dubbo.remoting.Channel v;
v := @this: org.apache.dubbo.remoting.transport.AbstractClient;
v := @parameter: java.lang.String;
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: org.apache.dubbo.remoting.Channel getChannel()>();
if v != null goto label;
return;
label:
interfaceinvoke v.<org.apache.dubbo.remoting.Channel: void removeAttribute(java.lang.String)>(v);
return;
}
public boolean hasAttribute(java.lang.String)
{
org.apache.dubbo.remoting.transport.AbstractClient v;
java.lang.String v;
org.apache.dubbo.remoting.Channel v;
boolean v;
v := @this: org.apache.dubbo.remoting.transport.AbstractClient;
v := @parameter: java.lang.String;
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: org.apache.dubbo.remoting.Channel getChannel()>();
if v != null goto label;
return 0;
label:
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: boolean hasAttribute(java.lang.String)>(v);
return v;
}
public void send(java.lang.Object, boolean) throws org.apache.dubbo.remoting.RemotingException
{
org.apache.dubbo.remoting.RemotingException v;
org.apache.dubbo.remoting.Channel v;
org.apache.dubbo.common.URL v;
org.apache.dubbo.remoting.transport.AbstractClient v;
java.lang.Object v;
java.lang.String v;
boolean v, v, v, v;
v := @this: org.apache.dubbo.remoting.transport.AbstractClient;
v := @parameter: java.lang.Object;
v := @parameter: boolean;
v = v.<org.apache.dubbo.remoting.transport.AbstractClient: boolean needReconnect>;
if v == 0 goto label;
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: boolean isConnected()>();
if v != 0 goto label;
virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: void connect()>();
label:
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: org.apache.dubbo.remoting.Channel getChannel()>();
if v == null goto label;
v = interfaceinvoke v.<org.apache.dubbo.remoting.Channel: boolean isConnected()>();
if v != 0 goto label;
label:
v = new org.apache.dubbo.remoting.RemotingException;
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: org.apache.dubbo.common.URL getUrl()>();
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[])>("message can not send, because channel is closed . url:\u0001");
specialinvoke v.<org.apache.dubbo.remoting.RemotingException: void <init>(org.apache.dubbo.remoting.Channel,java.lang.String)>(v, v);
throw v;
label:
interfaceinvoke v.<org.apache.dubbo.remoting.Channel: void send(java.lang.Object,boolean)>(v, v);
return;
}
protected void connect() throws org.apache.dubbo.remoting.RemotingException
{
org.apache.dubbo.remoting.RemotingException v, v, v;
boolean v, v, v, v, v;
java.net.InetSocketAddress v, v, v, v;
org.apache.dubbo.remoting.Channel v;
java.lang.Throwable v;
org.apache.dubbo.remoting.transport.AbstractClient v;
int v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
org.apache.dubbo.common.logger.Logger v, v, v;
java.util.concurrent.locks.Lock v, v, v, v;
java.lang.Class v, v, v, v;
v := @this: org.apache.dubbo.remoting.transport.AbstractClient;
v = v.<org.apache.dubbo.remoting.transport.AbstractClient: java.util.concurrent.locks.Lock connectLock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void lock()>();
label:
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: boolean isConnected()>();
if v == 0 goto label;
label:
v = v.<org.apache.dubbo.remoting.transport.AbstractClient: java.util.concurrent.locks.Lock connectLock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
return;
label:
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: boolean isClosed()>();
if v != 0 goto label;
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: boolean isClosing()>();
if v == 0 goto label;
label:
v = <org.apache.dubbo.remoting.transport.AbstractClient: org.apache.dubbo.common.logger.Logger logger>;
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: java.net.InetSocketAddress getRemoteAddress()>();
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getSimpleName()>();
v = staticinvoke <org.apache.dubbo.common.utils.NetUtils: java.lang.String getLocalHost()>();
v = staticinvoke <org.apache.dubbo.common.Version: java.lang.String getVersion()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.net.InetSocketAddress,java.lang.String,java.lang.String,java.lang.String)>(v, 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[])>("No need to connect to server \u from \u \u using dubbo version \u, cause: client status is closed or closing.");
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void warn(java.lang.String)>(v);
label:
v = v.<org.apache.dubbo.remoting.transport.AbstractClient: java.util.concurrent.locks.Lock connectLock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
return;
label:
virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: void doConnect()>();
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: boolean isConnected()>();
if v != 0 goto label;
v = new org.apache.dubbo.remoting.RemotingException;
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: java.net.InetSocketAddress getRemoteAddress()>();
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getSimpleName()>();
v = staticinvoke <org.apache.dubbo.common.utils.NetUtils: java.lang.String getLocalHost()>();
v = staticinvoke <org.apache.dubbo.common.Version: java.lang.String getVersion()>();
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: int getConnectTimeout()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.net.InetSocketAddress,java.lang.String,java.lang.String,java.lang.String,int)>(v, v, 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 connect to server \u from \u \u using dubbo version \u, cause: Connect wait timeout: \u0001ms.");
specialinvoke v.<org.apache.dubbo.remoting.RemotingException: void <init>(org.apache.dubbo.remoting.Channel,java.lang.String)>(v, v);
throw v;
label:
v = <org.apache.dubbo.remoting.transport.AbstractClient: org.apache.dubbo.common.logger.Logger logger>;
v = interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: boolean isInfoEnabled()>();
if v == 0 goto label;
v = <org.apache.dubbo.remoting.transport.AbstractClient: org.apache.dubbo.common.logger.Logger logger>;
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: java.net.InetSocketAddress getRemoteAddress()>();
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getSimpleName()>();
v = staticinvoke <org.apache.dubbo.common.utils.NetUtils: java.lang.String getLocalHost()>();
v = staticinvoke <org.apache.dubbo.common.Version: java.lang.String getVersion()>();
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: org.apache.dubbo.remoting.Channel getChannel()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.net.InetSocketAddress,java.lang.String,java.lang.String,java.lang.String,org.apache.dubbo.remoting.Channel)>(v, v, 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[])>("Successed connect to server \u from \u \u using dubbo version \u, channel is \u0001");
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void info(java.lang.String)>(v);
label:
v = v.<org.apache.dubbo.remoting.transport.AbstractClient: java.util.concurrent.locks.Lock connectLock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
v = new org.apache.dubbo.remoting.RemotingException;
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: java.net.InetSocketAddress getRemoteAddress()>();
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getSimpleName()>();
v = staticinvoke <org.apache.dubbo.common.utils.NetUtils: java.lang.String getLocalHost()>();
v = staticinvoke <org.apache.dubbo.common.Version: java.lang.String getVersion()>();
v = virtualinvoke v.<java.lang.Throwable: java.lang.String getMessage()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.net.InetSocketAddress,java.lang.String,java.lang.String,java.lang.String,java.lang.String)>(v, v, 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 connect to server \u from \u \u using dubbo version \u, cause: \u0001");
specialinvoke v.<org.apache.dubbo.remoting.RemotingException: void <init>(org.apache.dubbo.remoting.Channel,java.lang.String,java.lang.Throwable)>(v, v, v);
throw v;
label:
return;
catch org.apache.dubbo.remoting.RemotingException 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;
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;
}
public void disconnect()
{
java.lang.Throwable v, v, v;
org.apache.dubbo.common.logger.Logger v, v;
org.apache.dubbo.remoting.Channel v;
java.util.concurrent.locks.Lock v, v, v;
org.apache.dubbo.remoting.transport.AbstractClient v;
java.lang.String v, v;
v := @this: org.apache.dubbo.remoting.transport.AbstractClient;
v = v.<org.apache.dubbo.remoting.transport.AbstractClient: java.util.concurrent.locks.Lock connectLock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void lock()>();
label:
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: org.apache.dubbo.remoting.Channel getChannel()>();
if v == null goto label;
interfaceinvoke v.<org.apache.dubbo.remoting.Channel: void close()>();
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.dubbo.remoting.transport.AbstractClient: 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:
virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: void doDisConnect()>();
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.dubbo.remoting.transport.AbstractClient: 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.<org.apache.dubbo.remoting.transport.AbstractClient: java.util.concurrent.locks.Lock connectLock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.dubbo.remoting.transport.AbstractClient: java.util.concurrent.locks.Lock connectLock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: 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;
}
public void reconnect() throws org.apache.dubbo.remoting.RemotingException
{
java.lang.Throwable v;
java.util.concurrent.locks.Lock v, v, v;
org.apache.dubbo.remoting.transport.AbstractClient v;
boolean v, v;
v := @this: org.apache.dubbo.remoting.transport.AbstractClient;
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: boolean isConnected()>();
if v != 0 goto label;
v = v.<org.apache.dubbo.remoting.transport.AbstractClient: java.util.concurrent.locks.Lock connectLock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void lock()>();
label:
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: boolean isConnected()>();
if v != 0 goto label;
virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: void disconnect()>();
virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: void connect()>();
label:
v = v.<org.apache.dubbo.remoting.transport.AbstractClient: java.util.concurrent.locks.Lock connectLock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.dubbo.remoting.transport.AbstractClient: java.util.concurrent.locks.Lock connectLock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
public void close()
{
java.lang.Throwable v, v, v;
org.apache.dubbo.remoting.transport.AbstractClient v;
java.lang.String v, v, v, v, v, v, v, v, v, v;
boolean v, v;
org.apache.dubbo.common.logger.Logger v, v, v, v;
java.net.InetSocketAddress v, v;
java.util.concurrent.locks.Lock v, v, v, v;
java.lang.Class v, v;
v := @this: org.apache.dubbo.remoting.transport.AbstractClient;
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: boolean isClosed()>();
if v == 0 goto label;
v = <org.apache.dubbo.remoting.transport.AbstractClient: org.apache.dubbo.common.logger.Logger logger>;
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: java.net.InetSocketAddress getRemoteAddress()>();
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getSimpleName()>();
v = staticinvoke <org.apache.dubbo.common.utils.NetUtils: java.lang.String getLocalHost()>();
v = staticinvoke <org.apache.dubbo.common.Version: java.lang.String getVersion()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.net.InetSocketAddress,java.lang.String,java.lang.String,java.lang.String)>(v, 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[])>("No need to close connection to server \u from \u \u using dubbo version \u, cause: the client status is closed.");
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void warn(java.lang.String)>(v);
return;
label:
v = v.<org.apache.dubbo.remoting.transport.AbstractClient: java.util.concurrent.locks.Lock connectLock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void lock()>();
label:
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: boolean isClosed()>();
if v == 0 goto label;
v = <org.apache.dubbo.remoting.transport.AbstractClient: org.apache.dubbo.common.logger.Logger logger>;
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: java.net.InetSocketAddress getRemoteAddress()>();
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getSimpleName()>();
v = staticinvoke <org.apache.dubbo.common.utils.NetUtils: java.lang.String getLocalHost()>();
v = staticinvoke <org.apache.dubbo.common.Version: java.lang.String getVersion()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.net.InetSocketAddress,java.lang.String,java.lang.String,java.lang.String)>(v, 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[])>("No need to close connection to server \u from \u \u using dubbo version \u, cause: the client status is closed.");
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void warn(java.lang.String)>(v);
label:
v = v.<org.apache.dubbo.remoting.transport.AbstractClient: java.util.concurrent.locks.Lock connectLock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
return;
label:
virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: void disconnect()>();
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.dubbo.remoting.transport.AbstractClient: 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:
virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: void doClose()>();
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.dubbo.remoting.transport.AbstractClient: 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.<org.apache.dubbo.remoting.transport.AbstractClient: java.util.concurrent.locks.Lock connectLock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.dubbo.remoting.transport.AbstractClient: java.util.concurrent.locks.Lock connectLock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: 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;
catch java.lang.Throwable from label to label with label;
}
public void close(int)
{
int v;
org.apache.dubbo.remoting.transport.AbstractClient v;
v := @this: org.apache.dubbo.remoting.transport.AbstractClient;
v := @parameter: int;
virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: void close()>();
return;
}
public java.lang.String toString()
{
org.apache.dubbo.remoting.transport.AbstractClient v;
java.lang.Class v;
java.lang.String v, v;
java.net.InetSocketAddress v, v;
v := @this: org.apache.dubbo.remoting.transport.AbstractClient;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: java.net.InetSocketAddress getLocalAddress()>();
v = virtualinvoke v.<org.apache.dubbo.remoting.transport.AbstractClient: java.net.InetSocketAddress getRemoteAddress()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.net.InetSocketAddress,java.net.InetSocketAddress)>(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[])>("\u [\u -> \u]");
return v;
}
protected abstract void doOpen() throws java.lang.Throwable;
protected abstract void doClose() throws java.lang.Throwable;
protected abstract void doConnect() throws java.lang.Throwable;
protected abstract void doDisConnect() throws java.lang.Throwable;
protected abstract org.apache.dubbo.remoting.Channel getChannel();
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/remoting/transport/AbstractClient;");
<org.apache.dubbo.remoting.transport.AbstractClient: org.apache.dubbo.common.logger.Logger logger> = v;
return;
}
}