public class org.apache.dubbo.rpc.RpcStatus extends java.lang.Object
{
private static final java.util.concurrent.ConcurrentMap SERVICE_STATISTICS;
private static final java.util.concurrent.ConcurrentMap METHOD_STATISTICS;
private final java.util.concurrent.ConcurrentMap values;
private final java.util.concurrent.atomic.AtomicInteger active;
private final java.util.concurrent.atomic.AtomicLong total;
private final java.util.concurrent.atomic.AtomicInteger failed;
private final java.util.concurrent.atomic.AtomicLong totalElapsed;
private final java.util.concurrent.atomic.AtomicLong failedElapsed;
private final java.util.concurrent.atomic.AtomicLong maxElapsed;
private final java.util.concurrent.atomic.AtomicLong failedMaxElapsed;
private final java.util.concurrent.atomic.AtomicLong succeededMaxElapsed;
private void <init>()
{
java.util.concurrent.ConcurrentHashMap v;
java.util.concurrent.atomic.AtomicLong v, v, v, v, v, v;
java.util.concurrent.atomic.AtomicInteger v, v;
org.apache.dubbo.rpc.RpcStatus v;
v := @this: org.apache.dubbo.rpc.RpcStatus;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new java.util.concurrent.ConcurrentHashMap;
specialinvoke v.<java.util.concurrent.ConcurrentHashMap: void <init>()>();
v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.ConcurrentMap values> = v;
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>()>();
v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicInteger active> = v;
v = new java.util.concurrent.atomic.AtomicLong;
specialinvoke v.<java.util.concurrent.atomic.AtomicLong: void <init>()>();
v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicLong total> = v;
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>()>();
v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicInteger failed> = v;
v = new java.util.concurrent.atomic.AtomicLong;
specialinvoke v.<java.util.concurrent.atomic.AtomicLong: void <init>()>();
v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicLong totalElapsed> = v;
v = new java.util.concurrent.atomic.AtomicLong;
specialinvoke v.<java.util.concurrent.atomic.AtomicLong: void <init>()>();
v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicLong failedElapsed> = v;
v = new java.util.concurrent.atomic.AtomicLong;
specialinvoke v.<java.util.concurrent.atomic.AtomicLong: void <init>()>();
v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicLong maxElapsed> = v;
v = new java.util.concurrent.atomic.AtomicLong;
specialinvoke v.<java.util.concurrent.atomic.AtomicLong: void <init>()>();
v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicLong failedMaxElapsed> = v;
v = new java.util.concurrent.atomic.AtomicLong;
specialinvoke v.<java.util.concurrent.atomic.AtomicLong: void <init>()>();
v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicLong succeededMaxElapsed> = v;
return;
}
public static org.apache.dubbo.rpc.RpcStatus getStatus(org.apache.dubbo.common.URL)
{
org.apache.dubbo.common.URL v;
java.lang.Object v;
java.lang.String v;
java.util.function.Function v;
java.util.concurrent.ConcurrentMap v;
v := @parameter: org.apache.dubbo.common.URL;
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String toIdentityString()>();
v = <org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.ConcurrentMap SERVICE_STATISTICS>;
v = staticinvoke <org.apache.dubbo.rpc.RpcStatus$lambda_getStatus_0__406: java.util.function.Function bootstrap$()>();
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object computeIfAbsent(java.lang.Object,java.util.function.Function)>(v, v);
return v;
}
public static void removeStatus(org.apache.dubbo.common.URL)
{
org.apache.dubbo.common.URL v;
java.lang.String v;
java.util.concurrent.ConcurrentMap v;
v := @parameter: org.apache.dubbo.common.URL;
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String toIdentityString()>();
v = <org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.ConcurrentMap SERVICE_STATISTICS>;
interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object remove(java.lang.Object)>(v);
return;
}
public static org.apache.dubbo.rpc.RpcStatus getStatus(org.apache.dubbo.common.URL, java.lang.String)
{
java.util.function.Function v, v;
java.util.concurrent.ConcurrentMap v;
org.apache.dubbo.common.URL v;
java.lang.Object v, v;
java.lang.String v, v;
v := @parameter: org.apache.dubbo.common.URL;
v := @parameter: java.lang.String;
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String toIdentityString()>();
v = <org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.ConcurrentMap METHOD_STATISTICS>;
v = staticinvoke <org.apache.dubbo.rpc.RpcStatus$lambda_getStatus_1__407: java.util.function.Function bootstrap$()>();
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object computeIfAbsent(java.lang.Object,java.util.function.Function)>(v, v);
v = staticinvoke <org.apache.dubbo.rpc.RpcStatus$lambda_getStatus_2__408: java.util.function.Function bootstrap$()>();
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object computeIfAbsent(java.lang.Object,java.util.function.Function)>(v, v);
return v;
}
public static void removeStatus(org.apache.dubbo.common.URL, java.lang.String)
{
org.apache.dubbo.common.URL v;
java.lang.Object v;
java.lang.String v, v;
java.util.concurrent.ConcurrentMap v;
v := @parameter: org.apache.dubbo.common.URL;
v := @parameter: java.lang.String;
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String toIdentityString()>();
v = <org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.ConcurrentMap METHOD_STATISTICS>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object remove(java.lang.Object)>(v);
label:
return;
}
public static void beginCount(org.apache.dubbo.common.URL, java.lang.String)
{
org.apache.dubbo.common.URL v;
java.lang.String v;
v := @parameter: org.apache.dubbo.common.URL;
v := @parameter: java.lang.String;
staticinvoke <org.apache.dubbo.rpc.RpcStatus: boolean beginCount(org.apache.dubbo.common.URL,java.lang.String,int)>(v, v, 2147483647);
return;
}
public static boolean beginCount(org.apache.dubbo.common.URL, java.lang.String, int)
{
org.apache.dubbo.common.URL v;
java.util.concurrent.atomic.AtomicInteger v, v, v, v;
int v, v, v, v, v, v, v;
java.lang.String v;
org.apache.dubbo.rpc.RpcStatus v, v;
boolean v;
v := @parameter: org.apache.dubbo.common.URL;
v := @parameter: java.lang.String;
v := @parameter: int;
if v > 0 goto label;
v = 2147483647;
goto label;
label:
v = v;
label:
v = v;
v = staticinvoke <org.apache.dubbo.rpc.RpcStatus: org.apache.dubbo.rpc.RpcStatus getStatus(org.apache.dubbo.common.URL)>(v);
v = staticinvoke <org.apache.dubbo.rpc.RpcStatus: org.apache.dubbo.rpc.RpcStatus getStatus(org.apache.dubbo.common.URL,java.lang.String)>(v, v);
v = v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicInteger active>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
if v != 2147483647 goto label;
return 0;
label:
v = v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicInteger active>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
if v == 2147483647 goto label;
v = v + 1;
if v <= v goto label;
label:
return 0;
label:
v = v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicInteger active>;
v = v + 1;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: boolean compareAndSet(int,int)>(v, v);
if v == 0 goto label;
v = v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicInteger active>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int incrementAndGet()>();
return 1;
}
public static void endCount(org.apache.dubbo.common.URL, java.lang.String, long, boolean)
{
org.apache.dubbo.common.URL v;
long v;
java.lang.String v;
org.apache.dubbo.rpc.RpcStatus v, v;
boolean v;
v := @parameter: org.apache.dubbo.common.URL;
v := @parameter: java.lang.String;
v := @parameter: long;
v := @parameter: boolean;
v = staticinvoke <org.apache.dubbo.rpc.RpcStatus: org.apache.dubbo.rpc.RpcStatus getStatus(org.apache.dubbo.common.URL)>(v);
staticinvoke <org.apache.dubbo.rpc.RpcStatus: void endCount(org.apache.dubbo.rpc.RpcStatus,long,boolean)>(v, v, v);
v = staticinvoke <org.apache.dubbo.rpc.RpcStatus: org.apache.dubbo.rpc.RpcStatus getStatus(org.apache.dubbo.common.URL,java.lang.String)>(v, v);
staticinvoke <org.apache.dubbo.rpc.RpcStatus: void endCount(org.apache.dubbo.rpc.RpcStatus,long,boolean)>(v, v, v);
return;
}
private static void endCount(org.apache.dubbo.rpc.RpcStatus, long, boolean)
{
long v, v, v, v;
byte v, v, v;
java.util.concurrent.atomic.AtomicInteger v, v;
org.apache.dubbo.rpc.RpcStatus v;
boolean v;
java.util.concurrent.atomic.AtomicLong v, v, v, v, v, v, v, v, v;
v := @parameter: org.apache.dubbo.rpc.RpcStatus;
v := @parameter: long;
v := @parameter: boolean;
v = v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicInteger active>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int decrementAndGet()>();
v = v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicLong total>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long incrementAndGet()>();
v = v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicLong totalElapsed>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long addAndGet(long)>(v);
v = v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicLong maxElapsed>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long get()>();
v = v cmp v;
if v >= 0 goto label;
v = v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicLong maxElapsed>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: void set(long)>(v);
label:
if v == 0 goto label;
v = v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicLong succeededMaxElapsed>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long get()>();
v = v cmp v;
if v >= 0 goto label;
v = v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicLong succeededMaxElapsed>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: void set(long)>(v);
goto label;
label:
v = v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicInteger failed>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int incrementAndGet()>();
v = v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicLong failedElapsed>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long addAndGet(long)>(v);
v = v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicLong failedMaxElapsed>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long get()>();
v = v cmp v;
if v >= 0 goto label;
v = v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicLong failedMaxElapsed>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: void set(long)>(v);
label:
return;
}
public void set(java.lang.String, java.lang.Object)
{
java.lang.Object v;
java.lang.String v;
org.apache.dubbo.rpc.RpcStatus v;
java.util.concurrent.ConcurrentMap v;
v := @this: org.apache.dubbo.rpc.RpcStatus;
v := @parameter: java.lang.String;
v := @parameter: java.lang.Object;
v = v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.ConcurrentMap values>;
interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
return;
}
public java.lang.Object get(java.lang.String)
{
java.lang.Object v;
java.lang.String v;
org.apache.dubbo.rpc.RpcStatus v;
java.util.concurrent.ConcurrentMap v;
v := @this: org.apache.dubbo.rpc.RpcStatus;
v := @parameter: java.lang.String;
v = v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.ConcurrentMap values>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object get(java.lang.Object)>(v);
return v;
}
public int getActive()
{
int v;
org.apache.dubbo.rpc.RpcStatus v;
java.util.concurrent.atomic.AtomicInteger v;
v := @this: org.apache.dubbo.rpc.RpcStatus;
v = v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicInteger active>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
return v;
}
public long getTotal()
{
java.util.concurrent.atomic.AtomicLong v;
long v;
org.apache.dubbo.rpc.RpcStatus v;
v := @this: org.apache.dubbo.rpc.RpcStatus;
v = v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicLong total>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long longValue()>();
return v;
}
public long getTotalElapsed()
{
java.util.concurrent.atomic.AtomicLong v;
long v;
org.apache.dubbo.rpc.RpcStatus v;
v := @this: org.apache.dubbo.rpc.RpcStatus;
v = v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicLong totalElapsed>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long get()>();
return v;
}
public long getAverageElapsed()
{
byte v;
long v, v, v;
org.apache.dubbo.rpc.RpcStatus v;
v := @this: org.apache.dubbo.rpc.RpcStatus;
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcStatus: long getTotal()>();
v = v cmp 0L;
if v != 0 goto label;
return 0L;
label:
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcStatus: long getTotalElapsed()>();
v = v / v;
return v;
}
public long getMaxElapsed()
{
java.util.concurrent.atomic.AtomicLong v;
long v;
org.apache.dubbo.rpc.RpcStatus v;
v := @this: org.apache.dubbo.rpc.RpcStatus;
v = v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicLong maxElapsed>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long get()>();
return v;
}
public int getFailed()
{
int v;
org.apache.dubbo.rpc.RpcStatus v;
java.util.concurrent.atomic.AtomicInteger v;
v := @this: org.apache.dubbo.rpc.RpcStatus;
v = v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicInteger failed>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
return v;
}
public long getFailedElapsed()
{
java.util.concurrent.atomic.AtomicLong v;
long v;
org.apache.dubbo.rpc.RpcStatus v;
v := @this: org.apache.dubbo.rpc.RpcStatus;
v = v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicLong failedElapsed>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long get()>();
return v;
}
public long getFailedAverageElapsed()
{
byte v;
int v;
long v, v;
org.apache.dubbo.rpc.RpcStatus v;
v := @this: org.apache.dubbo.rpc.RpcStatus;
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcStatus: int getFailed()>();
v = v cmp 0L;
if v != 0 goto label;
return 0L;
label:
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcStatus: long getFailedElapsed()>();
v = v / v;
return v;
}
public long getFailedMaxElapsed()
{
java.util.concurrent.atomic.AtomicLong v;
long v;
org.apache.dubbo.rpc.RpcStatus v;
v := @this: org.apache.dubbo.rpc.RpcStatus;
v = v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicLong failedMaxElapsed>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long get()>();
return v;
}
public long getSucceeded()
{
int v;
long v, v;
org.apache.dubbo.rpc.RpcStatus v;
v := @this: org.apache.dubbo.rpc.RpcStatus;
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcStatus: long getTotal()>();
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcStatus: int getFailed()>();
v = v - v;
return v;
}
public long getSucceededElapsed()
{
long v, v, v;
org.apache.dubbo.rpc.RpcStatus v;
v := @this: org.apache.dubbo.rpc.RpcStatus;
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcStatus: long getTotalElapsed()>();
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcStatus: long getFailedElapsed()>();
v = v - v;
return v;
}
public long getSucceededAverageElapsed()
{
byte v;
long v, v, v;
org.apache.dubbo.rpc.RpcStatus v;
v := @this: org.apache.dubbo.rpc.RpcStatus;
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcStatus: long getSucceeded()>();
v = v cmp 0L;
if v != 0 goto label;
return 0L;
label:
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcStatus: long getSucceededElapsed()>();
v = v / v;
return v;
}
public long getSucceededMaxElapsed()
{
java.util.concurrent.atomic.AtomicLong v;
long v;
org.apache.dubbo.rpc.RpcStatus v;
v := @this: org.apache.dubbo.rpc.RpcStatus;
v = v.<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.atomic.AtomicLong succeededMaxElapsed>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long get()>();
return v;
}
public long getAverageTps()
{
long v, v, v, v, v, v;
byte v;
org.apache.dubbo.rpc.RpcStatus v;
v := @this: org.apache.dubbo.rpc.RpcStatus;
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcStatus: long getTotalElapsed()>();
v = v cmp 1000L;
if v < 0 goto label;
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcStatus: long getTotal()>();
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcStatus: long getTotalElapsed()>();
v = v / 1000L;
v = v / v;
return v;
label:
v = virtualinvoke v.<org.apache.dubbo.rpc.RpcStatus: long getTotal()>();
return v;
}
static void <clinit>()
{
java.util.concurrent.ConcurrentHashMap v, v;
v = new java.util.concurrent.ConcurrentHashMap;
specialinvoke v.<java.util.concurrent.ConcurrentHashMap: void <init>()>();
<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.ConcurrentMap SERVICE_STATISTICS> = v;
v = new java.util.concurrent.ConcurrentHashMap;
specialinvoke v.<java.util.concurrent.ConcurrentHashMap: void <init>()>();
<org.apache.dubbo.rpc.RpcStatus: java.util.concurrent.ConcurrentMap METHOD_STATISTICS> = v;
return;
}
}