From 8d3dd4017ee5fa5f3e97cde66b81f44327eb1e10 Mon Sep 17 00:00:00 2001 From: lilai Date: Wed, 7 Jun 2023 19:42:40 +0800 Subject: [PATCH] =?UTF-8?q?=E3=80=90enhancement=E3=80=91=E6=96=B0=E5=A2=9E?= =?UTF-8?q?springboot=E6=B3=A8=E5=86=8C=E6=8F=92=E4=BB=B6=E4=BA=8B?= =?UTF-8?q?=E4=BB=B6=E4=B8=8A=E6=8A=A5&=E6=94=AF=E6=8C=81stop=E6=96=B9?= =?UTF-8?q?=E6=B3=95=E4=B8=AD=E4=B8=8A=E6=8A=A5=E4=BA=8B=E4=BB=B6?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../plugin/service/PluginServiceManager.java | 11 +- .../sermant/core/service/ServiceConfig.java | 13 +-- .../sermant/core/service/ServiceManager.java | 72 ++++++++++-- .../webapp/frontend/src/views/EventsView.vue | 7 +- .../common/event/RouterEventCollector.java | 16 +-- .../common/event/RouterEventDefinition.java | 4 +- .../EffectStategyDynamicConfigListener.java | 2 + .../SpringBootRegistryEventCollector.java | 107 ++++++++++++++++++ .../SpringBootRegistryEventDefinition.java | 72 ++++++++++++ .../SpringApplicationInterceptor.java | 3 + .../service/registry/RegistryImpl.java | 4 + .../discovery/service/lb/rule/BaseTest.java | 5 + .../service/registry/RegistryImplTest.java | 4 + 13 files changed, 287 insertions(+), 33 deletions(-) create mode 100644 sermant-plugins/sermant-springboot-registry/springboot-registry-plugin/src/main/java/com/huawei/discovery/event/SpringBootRegistryEventCollector.java create mode 100644 sermant-plugins/sermant-springboot-registry/springboot-registry-plugin/src/main/java/com/huawei/discovery/event/SpringBootRegistryEventDefinition.java diff --git a/sermant-agentcore/sermant-agentcore-core/src/main/java/com/huaweicloud/sermant/core/plugin/service/PluginServiceManager.java b/sermant-agentcore/sermant-agentcore-core/src/main/java/com/huaweicloud/sermant/core/plugin/service/PluginServiceManager.java index 364907f805..560f82c2d8 100644 --- a/sermant-agentcore/sermant-agentcore-core/src/main/java/com/huaweicloud/sermant/core/plugin/service/PluginServiceManager.java +++ b/sermant-agentcore/sermant-agentcore-core/src/main/java/com/huaweicloud/sermant/core/plugin/service/PluginServiceManager.java @@ -17,8 +17,11 @@ package com.huaweicloud.sermant.core.plugin.service; import com.huaweicloud.sermant.core.common.LoggerFactory; +import com.huaweicloud.sermant.core.event.collector.FrameworkEventCollector; import com.huaweicloud.sermant.core.service.ServiceManager; +import java.util.ArrayList; +import java.util.List; import java.util.Locale; import java.util.ServiceLoader; import java.util.logging.Level; @@ -44,23 +47,27 @@ private PluginServiceManager() { * @param classLoader 插件服务包的ClassLoader */ public static void initPluginService(ClassLoader classLoader) { + List startServiceList = new ArrayList<>(); for (PluginService service : ServiceLoader.load(PluginService.class, classLoader)) { if (loadService(service, service.getClass(), PluginService.class)) { try { service.start(); + startServiceList.add(service.getClass().getName()); } catch (Exception ex) { - LOGGER.log(Level.SEVERE, String.format(Locale.ENGLISH, "Error occurs while starting plugin service: %s", + LOGGER.log(Level.SEVERE, String.format(Locale.ENGLISH, + "Error occurs while starting plugin service: %s", service.getClass()), ex); } } } + FrameworkEventCollector.getInstance().collectServiceStartEvent(startServiceList.toString()); } /** * 获取插件服务 * * @param serviceClass 插件服务类 - * @param 插件服务类型 + * @param 插件服务类型 * @return 插件服务实例 */ public static T getPluginService(Class serviceClass) { diff --git a/sermant-agentcore/sermant-agentcore-core/src/main/java/com/huaweicloud/sermant/core/service/ServiceConfig.java b/sermant-agentcore/sermant-agentcore-core/src/main/java/com/huaweicloud/sermant/core/service/ServiceConfig.java index 92ffc8bd0b..7041fb36ce 100644 --- a/sermant-agentcore/sermant-agentcore-core/src/main/java/com/huaweicloud/sermant/core/service/ServiceConfig.java +++ b/sermant-agentcore/sermant-agentcore-core/src/main/java/com/huaweicloud/sermant/core/service/ServiceConfig.java @@ -101,23 +101,22 @@ public void setDynamicConfigEnable(boolean dynamicConfigEnable) { * @return 是否开启了该服务 */ public boolean checkServiceEnable(String serviceName) { - if ("com.huaweicloud.sermant.implement.service.heartbeat.HeartbeatServiceImpl".equals(serviceName)) { + if (ServiceManager.HEARTBEAT_SERVICE_IMPL.equals(serviceName)) { return isHeartBeatEnable(); } - if ("com.huaweicloud.sermant.implement.service.send.netty.NettyGatewayClient".equals(serviceName)) { + if (ServiceManager.NETTY_GATEWAY_CLIENT.equals(serviceName)) { return isGatewayEnable(); } - if ("com.huaweicloud.sermant.implement.service.dynamicconfig.BufferedDynamicConfigService".equals( - serviceName)) { + if (ServiceManager.BUFFERED_DYNAMIC_CONFIG_SERVICE.equals(serviceName)) { return isDynamicConfigEnable(); } - if ("com.huaweicloud.sermant.implement.service.tracing.TracingServiceImpl".equals(serviceName)) { + if (ServiceManager.TRACING_SERVICE_IMPL.equals(serviceName)) { return isTracingEnable(); } - if ("com.huaweicloud.sermant.implement.service.visibility.VisibilityServiceImpl".equals(serviceName)) { + if (ServiceManager.VISIBILITY_SERVICE_IMPL.equals(serviceName)) { return isVisibilityEnable(); } - if ("com.huaweicloud.sermant.implement.service.inject.InjectServiceImpl".equals(serviceName)) { + if (ServiceManager.INJECT_SERVICE_IMPL.equals(serviceName)) { return isInjectEnable(); } return false; diff --git a/sermant-agentcore/sermant-agentcore-core/src/main/java/com/huaweicloud/sermant/core/service/ServiceManager.java b/sermant-agentcore/sermant-agentcore-core/src/main/java/com/huaweicloud/sermant/core/service/ServiceManager.java index 63be85ceb7..587cd704cf 100644 --- a/sermant-agentcore/sermant-agentcore-core/src/main/java/com/huaweicloud/sermant/core/service/ServiceManager.java +++ b/sermant-agentcore/sermant-agentcore-core/src/main/java/com/huaweicloud/sermant/core/service/ServiceManager.java @@ -28,6 +28,7 @@ import com.huaweicloud.sermant.core.event.EventManager; import com.huaweicloud.sermant.core.event.collector.FrameworkEventCollector; import com.huaweicloud.sermant.core.exception.DupServiceException; +import com.huaweicloud.sermant.core.service.send.api.GatewayClient; import com.huaweicloud.sermant.core.utils.SpiLoadUtils; import java.util.ArrayList; @@ -47,6 +48,42 @@ * @since 2021-10-26 */ public class ServiceManager { + /** + * 动态配置服务类名 + */ + public static final String BUFFERED_DYNAMIC_CONFIG_SERVICE = "com.huaweicloud.sermant" + + ".implement.service.dynamicconfig.BufferedDynamicConfigService"; + + /** + * 心跳服务类名 + */ + public static final String HEARTBEAT_SERVICE_IMPL = "com.huaweicloud.sermant.implement.service.heartbeat" + + ".HeartbeatServiceImpl"; + + /** + * 注入服务类名 + */ + public static final String INJECT_SERVICE_IMPL = "com.huaweicloud.sermant.implement.service.inject" + + ".InjectServiceImpl"; + + /** + * netty网关服务类名 + */ + public static final String NETTY_GATEWAY_CLIENT = "com.huaweicloud.sermant.implement.service.send.netty" + + ".NettyGatewayClient"; + + /** + * 链路追踪服务类名 + */ + public static final String TRACING_SERVICE_IMPL = "com.huaweicloud.sermant.implement.service.tracing" + + ".TracingServiceImpl"; + + /** + * 服务可见性服务类名 + */ + public static final String VISIBILITY_SERVICE_IMPL = "com.huaweicloud.sermant.implement.service.visibility" + + ".VisibilityServiceImpl"; + /** * 日志 */ @@ -141,17 +178,26 @@ public BaseService handle(BaseService source, BaseService target) { * 添加关闭服务的钩子 */ private static void addStopHook() { - Runtime.getRuntime().addShutdownHook(new Thread(new Runnable() { - @Override - public void run() { - offerEvent(); - for (BaseService baseService : new HashSet<>(SERVICES.values())) { - try { - baseService.stop(); - } catch (Exception ex) { - LOGGER.log(Level.SEVERE, String.format(Locale.ENGLISH, - "Error occurs while stopping service: %s", baseService.getClass().toString()), ex); - } + Runtime.getRuntime().addShutdownHook(new Thread(() -> { + BaseService nettyGateWayClient = SERVICES.get(NETTY_GATEWAY_CLIENT); + SERVICES.remove(NETTY_GATEWAY_CLIENT); + SERVICES.remove(GatewayClient.class.getCanonicalName()); + for (BaseService baseService : new HashSet<>(SERVICES.values())) { + try { + baseService.stop(); + } catch (Exception ex) { + LOGGER.log(Level.SEVERE, String.format(Locale.ENGLISH, + "Error occurs while stopping service: %s", baseService.getClass().toString()), ex); + } + } + offerEvent(); + if (nettyGateWayClient != null) { + try { + nettyGateWayClient.stop(); + } catch (Exception ex) { + LOGGER.log(Level.SEVERE, String.format(Locale.ENGLISH, + "Error occurs while stopping service: %s", + nettyGateWayClient.getClass().toString()), ex); } } })); @@ -159,9 +205,11 @@ public void run() { private static void offerEvent() { // 上报服务关闭事件 + ArrayList stopServiceArray = new ArrayList<>(); for (BaseService baseService : new HashSet<>(SERVICES.values())) { - FrameworkEventCollector.getInstance().collectServiceStopEvent(baseService.getClass().getName()); + stopServiceArray.add(baseService.getClass().getName()); } + FrameworkEventCollector.getInstance().collectServiceStopEvent(stopServiceArray.toString()); // 上报Sermant关闭的事件 FrameworkEventCollector.getInstance().collectAgentStopEvent(); diff --git a/sermant-backend/src/main/webapp/frontend/src/views/EventsView.vue b/sermant-backend/src/main/webapp/frontend/src/views/EventsView.vue index 9136ec4cae..5b81222c81 100644 --- a/sermant-backend/src/main/webapp/frontend/src/views/EventsView.vue +++ b/sermant-backend/src/main/webapp/frontend/src/views/EventsView.vue @@ -514,11 +514,14 @@ const eventName = reactive({ GRACEFUL_OFFLINE_BEGIN: "无损下线开始", GRACEFUL_OFFLINE_END: "无损下线结束", // 路由插件事件 - ROUTER_RULE_TAKE_EFFECT: "路由插件规则生效", + ROUTER_RULE_REFRESH: "路由插件规则刷新", SAME_TAG_RULE_MATCH: "同标签优先规则匹配成功", SAME_TAG_RULE_MISMATCH: "同标签优先规则匹配失败", INSTANCE_REMOVAL: "实例摘除", - INSTANCE_RECOVERY: "实例恢复" + INSTANCE_RECOVERY: "实例恢复", + SPRINGBOOT_REGISTRY: "SpringBoot服务注册", + SPRINGBOOT_UNREGISTRY: "SpringBoot服务移除注册", + SPRINGBOOT_GRAY_CONFIG_REFRESH: "SpringBoot注册插件灰度规则刷新" }); const displayState = reactive({ diff --git a/sermant-plugins/sermant-router/router-common/src/main/java/com/huaweicloud/sermant/router/common/event/RouterEventCollector.java b/sermant-plugins/sermant-router/router-common/src/main/java/com/huaweicloud/sermant/router/common/event/RouterEventCollector.java index dd54635a11..ce9755d69d 100644 --- a/sermant-plugins/sermant-router/router-common/src/main/java/com/huaweicloud/sermant/router/common/event/RouterEventCollector.java +++ b/sermant-plugins/sermant-router/router-common/src/main/java/com/huaweicloud/sermant/router/common/event/RouterEventCollector.java @@ -64,10 +64,10 @@ public void collectServiceRouteRuleEvent(String rule) { return; } String eventDescription = "Service router rule refresh:" + System.lineSeparator() + rule; - offerEvent(new Event(RouterEventDefinition.ROUTER_RULE_TAKE_EFFECT.getScope(), - RouterEventDefinition.ROUTER_RULE_TAKE_EFFECT.getEventLevel(), - RouterEventDefinition.ROUTER_RULE_TAKE_EFFECT.getEventType(), - new EventInfo(RouterEventDefinition.ROUTER_RULE_TAKE_EFFECT.getName(), eventDescription))); + offerEvent(new Event(RouterEventDefinition.ROUTER_RULE_REFRESH.getScope(), + RouterEventDefinition.ROUTER_RULE_REFRESH.getEventLevel(), + RouterEventDefinition.ROUTER_RULE_REFRESH.getEventType(), + new EventInfo(RouterEventDefinition.ROUTER_RULE_REFRESH.getName(), eventDescription))); } /** @@ -80,10 +80,10 @@ public void collectGlobalRouteRuleEvent(String rule) { return; } String eventDescription = "Global router rule refresh:" + System.lineSeparator() + rule; - offerEvent(new Event(RouterEventDefinition.ROUTER_RULE_TAKE_EFFECT.getScope(), - RouterEventDefinition.ROUTER_RULE_TAKE_EFFECT.getEventLevel(), - RouterEventDefinition.ROUTER_RULE_TAKE_EFFECT.getEventType(), - new EventInfo(RouterEventDefinition.ROUTER_RULE_TAKE_EFFECT.getName(), eventDescription))); + offerEvent(new Event(RouterEventDefinition.ROUTER_RULE_REFRESH.getScope(), + RouterEventDefinition.ROUTER_RULE_REFRESH.getEventLevel(), + RouterEventDefinition.ROUTER_RULE_REFRESH.getEventType(), + new EventInfo(RouterEventDefinition.ROUTER_RULE_REFRESH.getName(), eventDescription))); } /** diff --git a/sermant-plugins/sermant-router/router-common/src/main/java/com/huaweicloud/sermant/router/common/event/RouterEventDefinition.java b/sermant-plugins/sermant-router/router-common/src/main/java/com/huaweicloud/sermant/router/common/event/RouterEventDefinition.java index a77268794d..348c76dd03 100644 --- a/sermant-plugins/sermant-router/router-common/src/main/java/com/huaweicloud/sermant/router/common/event/RouterEventDefinition.java +++ b/sermant-plugins/sermant-router/router-common/src/main/java/com/huaweicloud/sermant/router/common/event/RouterEventDefinition.java @@ -27,10 +27,10 @@ */ public enum RouterEventDefinition { /** - * 路由插件规则生效事件 + * 路由插件规则刷新事件 */ - ROUTER_RULE_TAKE_EFFECT("ROUTER_RULE_TAKE_EFFECT", EventType.GOVERNANCE, EventLevel.NORMAL), + ROUTER_RULE_REFRESH("ROUTER_RULE_REFRESH", EventType.OPERATION, EventLevel.NORMAL), /** * 同TAG优先规则匹配生效 diff --git a/sermant-plugins/sermant-springboot-registry/springboot-registry-plugin/src/main/java/com/huawei/discovery/config/EffectStategyDynamicConfigListener.java b/sermant-plugins/sermant-springboot-registry/springboot-registry-plugin/src/main/java/com/huawei/discovery/config/EffectStategyDynamicConfigListener.java index 8ffb84e90c..1216122fd3 100644 --- a/sermant-plugins/sermant-springboot-registry/springboot-registry-plugin/src/main/java/com/huawei/discovery/config/EffectStategyDynamicConfigListener.java +++ b/sermant-plugins/sermant-springboot-registry/springboot-registry-plugin/src/main/java/com/huawei/discovery/config/EffectStategyDynamicConfigListener.java @@ -17,6 +17,7 @@ package com.huawei.discovery.config; import com.huawei.discovery.entity.PlugEffectStrategyCache; +import com.huawei.discovery.event.SpringBootRegistryEventCollector; import com.huaweicloud.sermant.core.common.LoggerFactory; import com.huaweicloud.sermant.core.service.dynamicconfig.common.DynamicConfigEvent; @@ -43,6 +44,7 @@ public void process(DynamicConfigEvent event) { + "[%s], " + "content [%s] ",event.getKey(), event.getEventType(), event.getContent())); if (StringUtils.equalsIgnoreCase(PlugEffectWhiteBlackConstants.DYNAMIC_CONFIG_LISTENER_KEY, event.getKey())) { PlugEffectStrategyCache.INSTANCE.resolve(event.getEventType(), event.getContent()); + SpringBootRegistryEventCollector.getInstance().collectGrayConfigRefreshEvent(event.getContent()); } } } diff --git a/sermant-plugins/sermant-springboot-registry/springboot-registry-plugin/src/main/java/com/huawei/discovery/event/SpringBootRegistryEventCollector.java b/sermant-plugins/sermant-springboot-registry/springboot-registry-plugin/src/main/java/com/huawei/discovery/event/SpringBootRegistryEventCollector.java new file mode 100644 index 0000000000..0e5d8e6617 --- /dev/null +++ b/sermant-plugins/sermant-springboot-registry/springboot-registry-plugin/src/main/java/com/huawei/discovery/event/SpringBootRegistryEventCollector.java @@ -0,0 +1,107 @@ +/* + * Copyright (C) 2023-2023 Huawei Technologies Co., Ltd. All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package com.huawei.discovery.event; + +import com.huawei.discovery.entity.DefaultServiceInstance; + +import com.huaweicloud.sermant.core.config.ConfigManager; +import com.huaweicloud.sermant.core.event.Event; +import com.huaweicloud.sermant.core.event.EventCollector; +import com.huaweicloud.sermant.core.event.EventInfo; +import com.huaweicloud.sermant.core.event.EventManager; +import com.huaweicloud.sermant.core.event.config.EventConfig; + +/** + * springboot注册插件事件采集器 + * + * @author lilai + * @since 2023-04-14 + */ +public class SpringBootRegistryEventCollector extends EventCollector { + private static volatile SpringBootRegistryEventCollector collector; + + private final EventConfig eventConfig = ConfigManager.getConfig(EventConfig.class); + + private SpringBootRegistryEventCollector() { + } + + /** + * 获取springboot注册插件事件采集器单例 + * + * @return springboot注册插件事件采集器单例 + */ + public static SpringBootRegistryEventCollector getInstance() { + if (collector == null) { + synchronized (SpringBootRegistryEventCollector.class) { + if (collector == null) { + collector = new SpringBootRegistryEventCollector(); + EventManager.registerCollector(SpringBootRegistryEventCollector.getInstance()); + } + } + } + return collector; + } + + /** + * 采集服务注册事件 + * + * @param instance 微服务实例 + */ + public void collectRegistryEvent(DefaultServiceInstance instance) { + if (!eventConfig.isEnable()) { + return; + } + String eventDescription = "Service instance register:" + instance.toString(); + offerEvent(new Event(SpringBootRegistryEventDefinition.SPRINGBOOT_REGISTRY.getScope(), + SpringBootRegistryEventDefinition.SPRINGBOOT_REGISTRY.getEventLevel(), + SpringBootRegistryEventDefinition.SPRINGBOOT_REGISTRY.getEventType(), + new EventInfo(SpringBootRegistryEventDefinition.SPRINGBOOT_REGISTRY.getName(), eventDescription))); + } + + /** + * 采集服务移除注册事件 + * + * @param instance 微服务实例 + */ + public void collectUnRegistryEvent(DefaultServiceInstance instance) { + if (!eventConfig.isEnable()) { + return; + } + String eventDescription = "Service instance unregister:" + instance.toString(); + offerEvent(new Event(SpringBootRegistryEventDefinition.SPRINGBOOT_UNREGISTRY.getScope(), + SpringBootRegistryEventDefinition.SPRINGBOOT_UNREGISTRY.getEventLevel(), + SpringBootRegistryEventDefinition.SPRINGBOOT_UNREGISTRY.getEventType(), + new EventInfo(SpringBootRegistryEventDefinition.SPRINGBOOT_UNREGISTRY.getName(), eventDescription))); + } + + /** + * 采集灰度配置刷新事件 + * + * @param config 灰度配置 + */ + public void collectGrayConfigRefreshEvent(String config) { + if (!eventConfig.isEnable()) { + return; + } + String eventDescription = "Gray config refresh:" + config; + offerEvent(new Event(SpringBootRegistryEventDefinition.SPRINGBOOT_GRAY_CONFIG_REFRESH.getScope(), + SpringBootRegistryEventDefinition.SPRINGBOOT_GRAY_CONFIG_REFRESH.getEventLevel(), + SpringBootRegistryEventDefinition.SPRINGBOOT_GRAY_CONFIG_REFRESH.getEventType(), + new EventInfo(SpringBootRegistryEventDefinition.SPRINGBOOT_GRAY_CONFIG_REFRESH.getName(), + eventDescription))); + } +} diff --git a/sermant-plugins/sermant-springboot-registry/springboot-registry-plugin/src/main/java/com/huawei/discovery/event/SpringBootRegistryEventDefinition.java b/sermant-plugins/sermant-springboot-registry/springboot-registry-plugin/src/main/java/com/huawei/discovery/event/SpringBootRegistryEventDefinition.java new file mode 100644 index 0000000000..c9373ec2f6 --- /dev/null +++ b/sermant-plugins/sermant-springboot-registry/springboot-registry-plugin/src/main/java/com/huawei/discovery/event/SpringBootRegistryEventDefinition.java @@ -0,0 +1,72 @@ +/* + * Copyright (C) 2023-2023 Huawei Technologies Co., Ltd. All rights reserved. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package com.huawei.discovery.event; + +import com.huaweicloud.sermant.core.event.EventLevel; +import com.huaweicloud.sermant.core.event.EventType; + +/** + * Springboot注册插件事件定义 + * + * @author lilai + * @since 2023-04-14 + */ +public enum SpringBootRegistryEventDefinition { + /** + * SpringBoot服务注册事件 + */ + SPRINGBOOT_REGISTRY("SPRINGBOOT_REGISTRY", EventType.GOVERNANCE, EventLevel.IMPORTANT), + + /** + * SpringBoot注册插件灰度配置刷新事件 + */ + SPRINGBOOT_GRAY_CONFIG_REFRESH("SPRINGBOOT_GRAY_CONFIG_REFRESH", EventType.OPERATION, EventLevel.NORMAL), + + /** + * SpringBoot服务移除注册事件 + */ + SPRINGBOOT_UNREGISTRY("SPRINGBOOT_UNREGISTRY", EventType.GOVERNANCE, + EventLevel.IMPORTANT); + + private final String name; + + private final EventType eventType; + + private final EventLevel eventLevel; + + SpringBootRegistryEventDefinition(String name, EventType eventType, EventLevel eventLevel) { + this.name = name; + this.eventType = eventType; + this.eventLevel = eventLevel; + } + + public String getName() { + return name; + } + + public EventType getEventType() { + return eventType; + } + + public EventLevel getEventLevel() { + return eventLevel; + } + + public String getScope() { + return "springboot-registry-plugin"; + } +} diff --git a/sermant-plugins/sermant-springboot-registry/springboot-registry-plugin/src/main/java/com/huawei/discovery/interceptors/SpringApplicationInterceptor.java b/sermant-plugins/sermant-springboot-registry/springboot-registry-plugin/src/main/java/com/huawei/discovery/interceptors/SpringApplicationInterceptor.java index 3f2313844d..c519facab3 100644 --- a/sermant-plugins/sermant-springboot-registry/springboot-registry-plugin/src/main/java/com/huawei/discovery/interceptors/SpringApplicationInterceptor.java +++ b/sermant-plugins/sermant-springboot-registry/springboot-registry-plugin/src/main/java/com/huawei/discovery/interceptors/SpringApplicationInterceptor.java @@ -17,6 +17,7 @@ package com.huawei.discovery.interceptors; import com.huawei.discovery.entity.RegisterContext; +import com.huawei.discovery.event.SpringBootRegistryEventCollector; import com.huawei.discovery.service.ConfigCenterService; import com.huawei.discovery.service.RegistryService; @@ -58,6 +59,8 @@ public ExecuteContext after(ExecuteContext context) { if ((logStartupInfo instanceof Boolean) && (Boolean) logStartupInfo && INIT.compareAndSet(false, true)) { registryService.registry(RegisterContext.INSTANCE.getServiceInstance()); configCenterService.init(RegisterContext.INSTANCE.getServiceInstance().getServiceName()); + SpringBootRegistryEventCollector.getInstance().collectRegistryEvent(RegisterContext.INSTANCE + .getServiceInstance()); } return context; } diff --git a/sermant-plugins/sermant-springboot-registry/springboot-registry-service/src/main/java/com/huawei/discovery/service/registry/RegistryImpl.java b/sermant-plugins/sermant-springboot-registry/springboot-registry-service/src/main/java/com/huawei/discovery/service/registry/RegistryImpl.java index 3de38a6ead..26b8a504fc 100644 --- a/sermant-plugins/sermant-springboot-registry/springboot-registry-service/src/main/java/com/huawei/discovery/service/registry/RegistryImpl.java +++ b/sermant-plugins/sermant-springboot-registry/springboot-registry-service/src/main/java/com/huawei/discovery/service/registry/RegistryImpl.java @@ -17,7 +17,9 @@ package com.huawei.discovery.service.registry; import com.huawei.discovery.config.DiscoveryPluginConfig; +import com.huawei.discovery.entity.RegisterContext; import com.huawei.discovery.entity.ServiceInstance; +import com.huawei.discovery.event.SpringBootRegistryEventCollector; import com.huawei.discovery.service.RegistryService; import com.huawei.discovery.service.lb.DiscoveryManager; @@ -71,6 +73,8 @@ public void shutdown() { LOGGER.log(Level.WARNING, "Stop lb service failed!", ex); } finally { addStatusForHeartbeat(); + SpringBootRegistryEventCollector.getInstance().collectUnRegistryEvent(RegisterContext.INSTANCE + .getServiceInstance()); } } } diff --git a/sermant-plugins/sermant-springboot-registry/springboot-registry-service/src/test/java/com/huawei/discovery/service/lb/rule/BaseTest.java b/sermant-plugins/sermant-springboot-registry/springboot-registry-service/src/test/java/com/huawei/discovery/service/lb/rule/BaseTest.java index 9aadb8d80d..324c251501 100644 --- a/sermant-plugins/sermant-springboot-registry/springboot-registry-service/src/test/java/com/huawei/discovery/service/lb/rule/BaseTest.java +++ b/sermant-plugins/sermant-springboot-registry/springboot-registry-service/src/test/java/com/huawei/discovery/service/lb/rule/BaseTest.java @@ -21,6 +21,7 @@ import com.huawei.discovery.service.lb.discovery.zk.ZkClient; import com.huawei.discovery.service.lb.utils.CommonUtils; +import com.huaweicloud.sermant.core.config.ConfigManager; import com.huaweicloud.sermant.core.plugin.config.PluginConfigManager; import com.huaweicloud.sermant.core.plugin.service.PluginServiceManager; import com.huaweicloud.sermant.core.utils.ReflectUtils; @@ -48,6 +49,8 @@ public class BaseTest { protected MockedStatic pluginConfigManagerMockedStatic; + protected MockedStatic configManagerMockedStatic; + @Before public void setUp() { pluginConfigManagerMockedStatic = Mockito @@ -58,6 +61,7 @@ public void setUp() { .thenReturn(new DiscoveryPluginConfig()); pluginServiceManagerMockedStatic = Mockito .mockStatic(PluginServiceManager.class); + configManagerMockedStatic = Mockito.mockStatic(ConfigManager.class); } @After @@ -65,6 +69,7 @@ public void tearDown() { CommonUtils.cleanServiceStats(); pluginConfigManagerMockedStatic.close(); pluginServiceManagerMockedStatic.close(); + configManagerMockedStatic.close(); } /** diff --git a/sermant-plugins/sermant-springboot-registry/springboot-registry-service/src/test/java/com/huawei/discovery/service/registry/RegistryImplTest.java b/sermant-plugins/sermant-springboot-registry/springboot-registry-service/src/test/java/com/huawei/discovery/service/registry/RegistryImplTest.java index 91d30f4002..4454a863a7 100644 --- a/sermant-plugins/sermant-springboot-registry/springboot-registry-service/src/test/java/com/huawei/discovery/service/registry/RegistryImplTest.java +++ b/sermant-plugins/sermant-springboot-registry/springboot-registry-service/src/test/java/com/huawei/discovery/service/registry/RegistryImplTest.java @@ -23,6 +23,8 @@ import com.huawei.discovery.service.lb.rule.BaseTest; import com.huawei.discovery.service.lb.utils.CommonUtils; +import com.huaweicloud.sermant.core.config.ConfigManager; +import com.huaweicloud.sermant.core.event.config.EventConfig; import com.huaweicloud.sermant.core.plugin.service.PluginServiceManager; import com.huaweicloud.sermant.core.utils.ReflectUtils; @@ -53,6 +55,8 @@ public void setUp() { MockitoAnnotations.openMocks(this); pluginServiceManagerMockedStatic.when(() -> PluginServiceManager.getPluginService(ZkService34.class)) .thenReturn(zkService34); + configManagerMockedStatic.when(() -> ConfigManager.getConfig(EventConfig.class)) + .thenReturn(new EventConfig()); start(); }