failover triggered mistakenly (#11536)
* Fix failover switch triggered mistakenly and optimise metrics * format code * Fix checkstyle * Fix unit test
This commit is contained in:
parent
4397e8d275
commit
2f2fc1b12b
@ -26,13 +26,17 @@ import com.alibaba.nacos.common.notify.NotifyCenter;
|
||||
import com.alibaba.nacos.common.spi.NacosServiceLoader;
|
||||
import com.alibaba.nacos.common.utils.JacksonUtils;
|
||||
import com.alibaba.nacos.common.utils.ThreadUtils;
|
||||
import io.micrometer.core.instrument.Gauge;
|
||||
import io.micrometer.core.instrument.Meter;
|
||||
import io.micrometer.core.instrument.Metrics;
|
||||
import io.micrometer.core.instrument.Meter;
|
||||
import io.micrometer.core.instrument.Tag;
|
||||
import io.micrometer.core.instrument.ImmutableTag;
|
||||
import io.micrometer.core.instrument.Gauge;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
import java.util.HashMap;
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
import java.util.ArrayList;
|
||||
import java.util.concurrent.ConcurrentHashMap;
|
||||
import java.util.concurrent.ScheduledExecutorService;
|
||||
import java.util.concurrent.ScheduledThreadPoolExecutor;
|
||||
@ -112,7 +116,7 @@ public class FailoverReactor implements Closeable {
|
||||
}
|
||||
|
||||
if (failoverMap.size() > 0) {
|
||||
failoverServiceCntMetrics(failoverMap);
|
||||
failoverServiceCntMetrics();
|
||||
serviceMap = failoverMap;
|
||||
}
|
||||
|
||||
@ -150,6 +154,10 @@ public class FailoverReactor implements Closeable {
|
||||
return failoverSwitchEnable;
|
||||
}
|
||||
|
||||
public boolean isFailoverSwitch(String serviceName) {
|
||||
return failoverSwitchEnable && serviceMap.containsKey(serviceName) && serviceMap.get(serviceName).ipCount() > 0;
|
||||
}
|
||||
|
||||
public ServiceInfo getService(String key) {
|
||||
ServiceInfo serviceInfo = serviceMap.get(key);
|
||||
|
||||
@ -174,15 +182,16 @@ public class FailoverReactor implements Closeable {
|
||||
NAMING_LOGGER.info("{} do shutdown stop", className);
|
||||
}
|
||||
|
||||
private void failoverServiceCntMetrics(Map<String, ServiceInfo> failoverMap) {
|
||||
private void failoverServiceCntMetrics() {
|
||||
try {
|
||||
for (Map.Entry<String, ServiceInfo> entry : failoverMap.entrySet()) {
|
||||
for (Map.Entry<String, ServiceInfo> entry : serviceMap.entrySet()) {
|
||||
String serviceName = entry.getKey();
|
||||
Gauge register = Gauge
|
||||
.builder("nacos_naming_client_failover_instances", failoverMap.get(serviceName).ipCount(),
|
||||
Integer::intValue).tag("service_name", serviceName)
|
||||
.description("Nacos failover data service count").register(Metrics.globalRegistry);
|
||||
meterMap.put(serviceName, register);
|
||||
List<Tag> tags = new ArrayList<>();
|
||||
tags.add(new ImmutableTag("service_name", serviceName));
|
||||
if (Metrics.globalRegistry.find("nacos_naming_client_failover_instances").tags(tags).gauge() == null) {
|
||||
Gauge.builder("nacos_naming_client_failover_instances", () -> serviceMap.get(serviceName).ipCount())
|
||||
.tags(tags).register(Metrics.globalRegistry);
|
||||
}
|
||||
}
|
||||
} catch (Exception e) {
|
||||
NAMING_LOGGER.info("[NA] registerFailoverServiceCnt fail.", e);
|
||||
@ -191,10 +200,13 @@ public class FailoverReactor implements Closeable {
|
||||
|
||||
private void failoverServiceCntMetricsClear() {
|
||||
try {
|
||||
for (Map.Entry<String, Meter> entry : meterMap.entrySet()) {
|
||||
Metrics.globalRegistry.remove(entry.getValue());
|
||||
for (Map.Entry<String, ServiceInfo> entry : serviceMap.entrySet()) {
|
||||
Gauge gauge = Metrics.globalRegistry.find("nacos_naming_client_failover_instances")
|
||||
.tag("service_name", entry.getKey()).gauge();
|
||||
if (gauge != null) {
|
||||
Metrics.globalRegistry.remove(gauge);
|
||||
}
|
||||
}
|
||||
meterMap.clear();
|
||||
} catch (Exception e) {
|
||||
NAMING_LOGGER.info("[NA] registerFailoverServiceCnt fail.", e);
|
||||
}
|
||||
|
@ -143,7 +143,7 @@ public class ServiceInfoHolder implements Closeable {
|
||||
if (changed) {
|
||||
NAMING_LOGGER.info("current ips:({}) service: {} -> {}", serviceInfo.ipCount(), serviceInfo.getKey(),
|
||||
JacksonUtils.toJson(serviceInfo.getHosts()));
|
||||
if (!failoverReactor.isFailoverSwitch()) {
|
||||
if (!failoverReactor.isFailoverSwitch(serviceKey)) {
|
||||
NotifyCenter.publishEvent(
|
||||
new InstancesChangeEvent(notifierEventScope, serviceInfo.getName(), serviceInfo.getGroupName(),
|
||||
serviceInfo.getClusters(), serviceInfo.getHosts()));
|
||||
|
@ -135,9 +135,9 @@ public class FailoverReactorTest {
|
||||
@Test
|
||||
public void testFailoverServiceCntMetrics()
|
||||
throws NoSuchMethodException, InvocationTargetException, IllegalAccessException {
|
||||
Method method = FailoverReactor.class.getDeclaredMethod("failoverServiceCntMetrics", Map.class);
|
||||
Method method = FailoverReactor.class.getDeclaredMethod("failoverServiceCntMetrics");
|
||||
method.setAccessible(true);
|
||||
method.invoke(failoverReactor, new Object[1]);
|
||||
method.invoke(failoverReactor);
|
||||
// No exception
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user