public class org.apache.dubbo.qos.server.Server extends java.lang.Object
{
private static final org.apache.dubbo.common.logger.Logger logger;
private static final org.apache.dubbo.qos.server.Server INSTANCE;
private java.lang.String host;
private int port;
private boolean acceptForeignIp;
private io.netty.channel.EventLoopGroup boss;
private io.netty.channel.EventLoopGroup worker;
private java.lang.String welcome;
private java.util.concurrent.atomic.AtomicBoolean started;
public static final org.apache.dubbo.qos.server.Server getInstance()
{
org.apache.dubbo.qos.server.Server v;
v = <org.apache.dubbo.qos.server.Server: org.apache.dubbo.qos.server.Server INSTANCE>;
return v;
}
private void <init>()
{
org.apache.dubbo.qos.server.Server v;
java.util.concurrent.atomic.AtomicBoolean v;
java.lang.String v;
v := @this: org.apache.dubbo.qos.server.Server;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.apache.dubbo.qos.server.Server: boolean acceptForeignIp> = 1;
v = new java.util.concurrent.atomic.AtomicBoolean;
specialinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void <init>()>();
v.<org.apache.dubbo.qos.server.Server: java.util.concurrent.atomic.AtomicBoolean started> = v;
v = <org.apache.dubbo.qos.server.DubboLogo: java.lang.String DUBBO>;
v.<org.apache.dubbo.qos.server.Server: java.lang.String welcome> = v;
return;
}
public void setWelcome(java.lang.String)
{
org.apache.dubbo.qos.server.Server v;
java.lang.String v;
v := @this: org.apache.dubbo.qos.server.Server;
v := @parameter: java.lang.String;
v.<org.apache.dubbo.qos.server.Server: java.lang.String welcome> = v;
return;
}
public int getPort()
{
int v;
org.apache.dubbo.qos.server.Server v;
v := @this: org.apache.dubbo.qos.server.Server;
v = v.<org.apache.dubbo.qos.server.Server: int port>;
return v;
}
public void start() throws java.lang.Throwable
{
java.lang.Throwable v;
org.apache.dubbo.qos.server.Server v;
io.netty.util.concurrent.DefaultThreadFactory v, v;
io.netty.channel.ChannelOption v, v;
org.apache.dubbo.qos.server.Server$1 v;
java.util.concurrent.atomic.AtomicBoolean v;
int v, v, v, v;
java.lang.Boolean v, v;
java.lang.String v, v, v, v;
boolean v, v;
io.netty.channel.EventLoopGroup v, v;
org.apache.dubbo.common.logger.Logger v, v;
io.netty.channel.nio.NioEventLoopGroup v, v;
io.netty.channel.ChannelFuture v, v;
io.netty.bootstrap.ServerBootstrap v;
v := @this: org.apache.dubbo.qos.server.Server;
v = v.<org.apache.dubbo.qos.server.Server: java.util.concurrent.atomic.AtomicBoolean started>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean compareAndSet(boolean,boolean)>(0, 1);
if v != 0 goto label;
return;
label:
v = new io.netty.channel.nio.NioEventLoopGroup;
v = new io.netty.util.concurrent.DefaultThreadFactory;
specialinvoke v.<io.netty.util.concurrent.DefaultThreadFactory: void <init>(java.lang.String,boolean)>("qos-boss", 1);
specialinvoke v.<io.netty.channel.nio.NioEventLoopGroup: void <init>(int,java.util.concurrent.ThreadFactory)>(1, v);
v.<org.apache.dubbo.qos.server.Server: io.netty.channel.EventLoopGroup boss> = v;
v = new io.netty.channel.nio.NioEventLoopGroup;
v = new io.netty.util.concurrent.DefaultThreadFactory;
specialinvoke v.<io.netty.util.concurrent.DefaultThreadFactory: void <init>(java.lang.String,boolean)>("qos-worker", 1);
specialinvoke v.<io.netty.channel.nio.NioEventLoopGroup: void <init>(int,java.util.concurrent.ThreadFactory)>(0, v);
v.<org.apache.dubbo.qos.server.Server: io.netty.channel.EventLoopGroup worker> = v;
v = new io.netty.bootstrap.ServerBootstrap;
specialinvoke v.<io.netty.bootstrap.ServerBootstrap: void <init>()>();
v = v.<org.apache.dubbo.qos.server.Server: io.netty.channel.EventLoopGroup boss>;
v = v.<org.apache.dubbo.qos.server.Server: io.netty.channel.EventLoopGroup worker>;
virtualinvoke v.<io.netty.bootstrap.ServerBootstrap: io.netty.bootstrap.ServerBootstrap group(io.netty.channel.EventLoopGroup,io.netty.channel.EventLoopGroup)>(v, v);
virtualinvoke v.<io.netty.bootstrap.ServerBootstrap: io.netty.bootstrap.AbstractBootstrap channel(java.lang.Class)>(class "Lio/netty/channel/socket/nio/NioServerSocketChannel;");
v = <io.netty.channel.ChannelOption: io.netty.channel.ChannelOption SO_REUSEADDR>;
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(1);
virtualinvoke v.<io.netty.bootstrap.ServerBootstrap: io.netty.bootstrap.AbstractBootstrap option(io.netty.channel.ChannelOption,java.lang.Object)>(v, v);
v = <io.netty.channel.ChannelOption: io.netty.channel.ChannelOption TCP_NODELAY>;
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(1);
virtualinvoke v.<io.netty.bootstrap.ServerBootstrap: io.netty.bootstrap.ServerBootstrap childOption(io.netty.channel.ChannelOption,java.lang.Object)>(v, v);
v = new org.apache.dubbo.qos.server.Server$1;
specialinvoke v.<org.apache.dubbo.qos.server.Server$1: void <init>(org.apache.dubbo.qos.server.Server)>(v);
virtualinvoke v.<io.netty.bootstrap.ServerBootstrap: io.netty.bootstrap.ServerBootstrap childHandler(io.netty.channel.ChannelHandler)>(v);
label:
v = v.<org.apache.dubbo.qos.server.Server: java.lang.String host>;
v = staticinvoke <org.apache.dubbo.common.utils.StringUtils: boolean isBlank(java.lang.CharSequence)>(v);
if v == 0 goto label;
v = v.<org.apache.dubbo.qos.server.Server: int port>;
v = virtualinvoke v.<io.netty.bootstrap.ServerBootstrap: io.netty.channel.ChannelFuture bind(int)>(v);
interfaceinvoke v.<io.netty.channel.ChannelFuture: io.netty.channel.ChannelFuture sync()>();
goto label;
label:
v = v.<org.apache.dubbo.qos.server.Server: java.lang.String host>;
v = v.<org.apache.dubbo.qos.server.Server: int port>;
v = virtualinvoke v.<io.netty.bootstrap.ServerBootstrap: io.netty.channel.ChannelFuture bind(java.lang.String,int)>(v, v);
interfaceinvoke v.<io.netty.channel.ChannelFuture: io.netty.channel.ChannelFuture sync()>();
label:
v = <org.apache.dubbo.qos.server.Server: org.apache.dubbo.common.logger.Logger logger>;
v = v.<org.apache.dubbo.qos.server.Server: int port>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(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[])>("qos-server bind localhost:\u0001");
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void info(java.lang.String)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.dubbo.qos.server.Server: org.apache.dubbo.common.logger.Logger logger>;
v = v.<org.apache.dubbo.qos.server.Server: int port>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(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[])>("qos-server can not bind localhost:\u0001");
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void error(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
public void stop()
{
org.apache.dubbo.qos.server.Server v;
io.netty.channel.EventLoopGroup v, v, v, v;
org.apache.dubbo.common.logger.Logger v;
v := @this: org.apache.dubbo.qos.server.Server;
v = <org.apache.dubbo.qos.server.Server: org.apache.dubbo.common.logger.Logger logger>;
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void info(java.lang.String)>("qos-server stopped.");
v = v.<org.apache.dubbo.qos.server.Server: io.netty.channel.EventLoopGroup boss>;
if v == null goto label;
v = v.<org.apache.dubbo.qos.server.Server: io.netty.channel.EventLoopGroup boss>;
interfaceinvoke v.<io.netty.channel.EventLoopGroup: io.netty.util.concurrent.Future shutdownGracefully()>();
label:
v = v.<org.apache.dubbo.qos.server.Server: io.netty.channel.EventLoopGroup worker>;
if v == null goto label;
v = v.<org.apache.dubbo.qos.server.Server: io.netty.channel.EventLoopGroup worker>;
interfaceinvoke v.<io.netty.channel.EventLoopGroup: io.netty.util.concurrent.Future shutdownGracefully()>();
label:
return;
}
public java.lang.String getHost()
{
org.apache.dubbo.qos.server.Server v;
java.lang.String v;
v := @this: org.apache.dubbo.qos.server.Server;
v = v.<org.apache.dubbo.qos.server.Server: java.lang.String host>;
return v;
}
public void setHost(java.lang.String)
{
org.apache.dubbo.qos.server.Server v;
java.lang.String v;
v := @this: org.apache.dubbo.qos.server.Server;
v := @parameter: java.lang.String;
v.<org.apache.dubbo.qos.server.Server: java.lang.String host> = v;
return;
}
public void setPort(int)
{
int v;
org.apache.dubbo.qos.server.Server v;
v := @this: org.apache.dubbo.qos.server.Server;
v := @parameter: int;
v.<org.apache.dubbo.qos.server.Server: int port> = v;
return;
}
public boolean isAcceptForeignIp()
{
org.apache.dubbo.qos.server.Server v;
boolean v;
v := @this: org.apache.dubbo.qos.server.Server;
v = v.<org.apache.dubbo.qos.server.Server: boolean acceptForeignIp>;
return v;
}
public void setAcceptForeignIp(boolean)
{
org.apache.dubbo.qos.server.Server v;
boolean v;
v := @this: org.apache.dubbo.qos.server.Server;
v := @parameter: boolean;
v.<org.apache.dubbo.qos.server.Server: boolean acceptForeignIp> = v;
return;
}
public java.lang.String getWelcome()
{
org.apache.dubbo.qos.server.Server v;
java.lang.String v;
v := @this: org.apache.dubbo.qos.server.Server;
v = v.<org.apache.dubbo.qos.server.Server: java.lang.String welcome>;
return v;
}
public boolean isStarted()
{
org.apache.dubbo.qos.server.Server v;
java.util.concurrent.atomic.AtomicBoolean v;
boolean v;
v := @this: org.apache.dubbo.qos.server.Server;
v = v.<org.apache.dubbo.qos.server.Server: java.util.concurrent.atomic.AtomicBoolean started>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean get()>();
return v;
}
static void <clinit>()
{
org.apache.dubbo.qos.server.Server v;
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/qos/server/Server;");
<org.apache.dubbo.qos.server.Server: org.apache.dubbo.common.logger.Logger logger> = v;
v = new org.apache.dubbo.qos.server.Server;
specialinvoke v.<org.apache.dubbo.qos.server.Server: void <init>()>();
<org.apache.dubbo.qos.server.Server: org.apache.dubbo.qos.server.Server INSTANCE> = v;
return;
}
}