class org.apache.dubbo.registry.redis.RedisRegistry$Notifier extends java.lang.Thread
{
private final java.lang.String service;
private final java.util.concurrent.atomic.AtomicInteger connectSkip;
private final java.util.concurrent.atomic.AtomicInteger connectSkipped;
private volatile boolean first;
private volatile boolean running;
private volatile int connectRandom;
final org.apache.dubbo.registry.redis.RedisRegistry this$0;
public void <init>(org.apache.dubbo.registry.redis.RedisRegistry, java.lang.String)
{
org.apache.dubbo.registry.redis.RedisRegistry$Notifier v;
java.util.concurrent.atomic.AtomicInteger v, v;
java.lang.String v;
org.apache.dubbo.registry.redis.RedisRegistry v;
v := @this: org.apache.dubbo.registry.redis.RedisRegistry$Notifier;
v := @parameter: org.apache.dubbo.registry.redis.RedisRegistry;
v := @parameter: java.lang.String;
v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: org.apache.dubbo.registry.redis.RedisRegistry this$0> = v;
specialinvoke v.<java.lang.Thread: void <init>()>();
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>()>();
v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: java.util.concurrent.atomic.AtomicInteger connectSkip> = v;
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>()>();
v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: java.util.concurrent.atomic.AtomicInteger connectSkipped> = v;
v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: boolean first> = 1;
v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: boolean running> = 1;
specialinvoke v.<java.lang.Thread: void setDaemon(boolean)>(1);
specialinvoke v.<java.lang.Thread: void setName(java.lang.String)>("DubboRedisSubscribe");
v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: java.lang.String service> = v;
return;
}
private void resetSkip()
{
org.apache.dubbo.registry.redis.RedisRegistry$Notifier v;
java.util.concurrent.atomic.AtomicInteger v, v;
v := @this: org.apache.dubbo.registry.redis.RedisRegistry$Notifier;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: java.util.concurrent.atomic.AtomicInteger connectSkip>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: void set(int)>(0);
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: java.util.concurrent.atomic.AtomicInteger connectSkipped>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: void set(int)>(0);
v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: int connectRandom> = 0;
return;
}
private boolean isSkip()
{
org.apache.dubbo.registry.redis.RedisRegistry$Notifier v;
java.util.concurrent.atomic.AtomicInteger v, v, v, v;
java.util.concurrent.ThreadLocalRandom v;
int v, v, v, v, v;
v := @this: org.apache.dubbo.registry.redis.RedisRegistry$Notifier;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: java.util.concurrent.atomic.AtomicInteger connectSkip>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
if v < 10 goto label;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: int connectRandom>;
if v != 0 goto label;
v = staticinvoke <java.util.concurrent.ThreadLocalRandom: java.util.concurrent.ThreadLocalRandom current()>();
v = virtualinvoke v.<java.util.concurrent.ThreadLocalRandom: int nextInt(int)>(10);
v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: int connectRandom> = v;
label:
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: int connectRandom>;
v = 10 + v;
label:
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: java.util.concurrent.atomic.AtomicInteger connectSkipped>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int getAndIncrement()>();
if v >= v goto label;
return 1;
label:
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: java.util.concurrent.atomic.AtomicInteger connectSkip>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int incrementAndGet()>();
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: java.util.concurrent.atomic.AtomicInteger connectSkipped>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: void set(int)>(0);
v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: int connectRandom> = 0;
return 0;
}
public void run()
{
org.apache.dubbo.common.URL v;
boolean v, v, v, v, v, v, v, v;
org.apache.dubbo.remoting.redis.RedisClient v, v, v, v;
java.util.Set v;
org.apache.dubbo.registry.redis.RedisRegistry v, v, v, v, v, v, v, v, v, v, v, v, v, v;
java.lang.Throwable v, v, v;
java.lang.String[] v, v;
int v, v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v;
java.util.Iterator v;
org.apache.dubbo.common.logger.Logger v, v, v;
org.apache.dubbo.registry.redis.RedisRegistry$Notifier v;
org.apache.dubbo.registry.redis.RedisRegistry$NotifySub v, v;
java.lang.Object v;
v := @this: org.apache.dubbo.registry.redis.RedisRegistry$Notifier;
label:
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: boolean running>;
if v == 0 goto label;
label:
v = specialinvoke v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: boolean isSkip()>();
if v != 0 goto label;
label:
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: org.apache.dubbo.registry.redis.RedisRegistry this$0>;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry: org.apache.dubbo.remoting.redis.RedisClient redisClient>;
v = interfaceinvoke v.<org.apache.dubbo.remoting.redis.RedisClient: boolean isConnected()>();
if v == 0 goto label;
label:
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: java.lang.String service>;
v = virtualinvoke v.<java.lang.String: boolean endsWith(java.lang.String)>("*");
if v == 0 goto label;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: boolean first>;
if v == 0 goto label;
v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: boolean first> = 0;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: org.apache.dubbo.registry.redis.RedisRegistry this$0>;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry: org.apache.dubbo.remoting.redis.RedisClient redisClient>;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: java.lang.String service>;
v = interfaceinvoke v.<org.apache.dubbo.remoting.redis.RedisClient: java.util.Set scan(java.lang.String)>(v);
v = staticinvoke <org.apache.dubbo.common.utils.CollectionUtils: boolean isNotEmpty(java.util.Collection)>(v);
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Set: 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()>();
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: org.apache.dubbo.registry.redis.RedisRegistry this$0>;
specialinvoke v.<org.apache.dubbo.registry.redis.RedisRegistry: void doNotify(java.lang.String)>(v);
goto label;
label:
specialinvoke v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: void resetSkip()>();
label:
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: org.apache.dubbo.registry.redis.RedisRegistry this$0>;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry: org.apache.dubbo.remoting.redis.RedisClient redisClient>;
v = new org.apache.dubbo.registry.redis.RedisRegistry$NotifySub;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: org.apache.dubbo.registry.redis.RedisRegistry this$0>;
specialinvoke v.<org.apache.dubbo.registry.redis.RedisRegistry$NotifySub: void <init>(org.apache.dubbo.registry.redis.RedisRegistry)>(v);
v = newarray (java.lang.String)[1];
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: java.lang.String service>;
v[0] = v;
interfaceinvoke v.<org.apache.dubbo.remoting.redis.RedisClient: void psubscribe(redis.clients.jedis.JedisPubSub,java.lang.String[])>(v, v);
goto label;
label:
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: boolean first>;
if v == 0 goto label;
v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: boolean first> = 0;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: org.apache.dubbo.registry.redis.RedisRegistry this$0>;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: java.lang.String service>;
specialinvoke v.<org.apache.dubbo.registry.redis.RedisRegistry: void doNotify(java.lang.String)>(v);
specialinvoke v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: void resetSkip()>();
label:
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: org.apache.dubbo.registry.redis.RedisRegistry this$0>;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry: org.apache.dubbo.remoting.redis.RedisClient redisClient>;
v = new org.apache.dubbo.registry.redis.RedisRegistry$NotifySub;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: org.apache.dubbo.registry.redis.RedisRegistry this$0>;
specialinvoke v.<org.apache.dubbo.registry.redis.RedisRegistry$NotifySub: void <init>(org.apache.dubbo.registry.redis.RedisRegistry)>(v);
v = newarray (java.lang.String)[1];
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: java.lang.String service>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(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[])>("\u0001/*");
v[0] = v;
interfaceinvoke v.<org.apache.dubbo.remoting.redis.RedisClient: void psubscribe(redis.clients.jedis.JedisPubSub,java.lang.String[])>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: org.apache.dubbo.registry.redis.RedisRegistry this$0>;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry: org.apache.dubbo.common.logger.Logger logger>;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: org.apache.dubbo.registry.redis.RedisRegistry this$0>;
v = virtualinvoke v.<org.apache.dubbo.registry.redis.RedisRegistry: org.apache.dubbo.common.URL getUrl()>();
v = virtualinvoke v.<org.apache.dubbo.common.URL: java.lang.String getAddress()>();
v = virtualinvoke v.<java.lang.Throwable: java.lang.String getMessage()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String)>(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 subscribe service from redis registry. registry: \u, cause: \u0001");
interfaceinvoke v.<org.apache.dubbo.common.logger.Logger: void warn(java.lang.String,java.lang.Throwable)>(v, v);
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: org.apache.dubbo.registry.redis.RedisRegistry this$0>;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry: int reconnectPeriod>;
staticinvoke <org.apache.dubbo.registry.redis.RedisRegistry$Notifier: void sleep(long)>(v);
label:
goto label;
label:
v := @caughtexception;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: org.apache.dubbo.registry.redis.RedisRegistry this$0>;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry: 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 error(java.lang.String,java.lang.Throwable)>(v, v);
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: org.apache.dubbo.registry.redis.RedisRegistry this$0>;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry: int reconnectPeriod>;
staticinvoke <org.apache.dubbo.registry.redis.RedisRegistry$Notifier: void sleep(long)>(v);
label:
goto label;
label:
v := @caughtexception;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: org.apache.dubbo.registry.redis.RedisRegistry this$0>;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry: 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 error(java.lang.String,java.lang.Throwable)>(v, v);
goto label;
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;
catch java.lang.Throwable from label to label with label;
}
public void shutdown()
{
java.lang.Throwable v;
org.apache.dubbo.registry.redis.RedisRegistry$Notifier v;
org.apache.dubbo.common.logger.Logger v;
org.apache.dubbo.remoting.redis.RedisClient v;
java.lang.String v;
org.apache.dubbo.registry.redis.RedisRegistry v, v;
v := @this: org.apache.dubbo.registry.redis.RedisRegistry$Notifier;
label:
v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: boolean running> = 0;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: org.apache.dubbo.registry.redis.RedisRegistry this$0>;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry: org.apache.dubbo.remoting.redis.RedisClient redisClient>;
interfaceinvoke v.<org.apache.dubbo.remoting.redis.RedisClient: void disconnect()>();
label:
goto label;
label:
v := @caughtexception;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry$Notifier: org.apache.dubbo.registry.redis.RedisRegistry this$0>;
v = v.<org.apache.dubbo.registry.redis.RedisRegistry: 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:
return;
catch java.lang.Throwable from label to label with label;
}
}