如下图, org.springframework.cloud.spring-cloud-commons 包下定义了一系列接口,其中就包括 serviceregistry 的系列规范,并通过SPI机制去调用接口实现。
在该包的 META-INF/spring.factories 文件中,可以找到 EnableAutoConfiguration.class 为key的value中有 AutoServiceRegistrationAutoConfiguration.class 这一项。
来看看这个 AutoServiceRegistrationAutoConfiguration 配置类:
对应的,在 com.alibaba.cloud. nacos 包下(位于spring-cloud-starter-nacos-discovery jar包中)的 META-INF/spring.fatories 有个nacos 服务注册 配置类,如下图:
这个 NacosServiceRegistryAutoConfiguration 配置类就定义了上面 SpringCloud 的 AutoServiceRegistration 接口的实现类:
package com.alibaba.cloud.nacos.registry;
...
/**
* @author xiaojing
* @author <a href="mailto:mercyblitz@gmail测试数据" rel="external nofollow" >Mercy</a>
*/
@Configuration(proxyBeanMethods = false)
@EnableConfigurationProperties
@ConditionalOnNacosDiscoveryEnabled
@ConditionalOnProperty(value = "spring.cloud.service-registry.auto-registration.enabled",
matchIfMissing = true)
@AutoConfigureAfter({ AutoServiceRegistrationConfiguration.class,
AutoServiceRegistrationAutoConfiguration.class,
NacosDiscoveryAutoConfiguration.class })
public class NacosServiceRegistryAutoConfiguration {
@Bean
public NacosServiceRegistry nacosServiceRegistry(
NacosDiscoveryProperties nacosDiscoveryProperties) {
return new NacosServiceRegistry(nacosDiscoveryProperties);
}
@Bean
@ConditionalOnBean(AutoServiceRegistrationProperties.class)
public NacosRegistration nacosRegistration(
ObjectProvider<List<NacosRegistrationCustomizer>> registrationCustomizers,
NacosDiscoveryProperties nacosDiscoveryProperties,
ApplicationContext context) {
return new NacosRegistration(registrationCustomizers.getIfAvailable(),
nacosDiscoveryProperties, context);
}
/**
** 这里,这个NacosAutoServiceRegistration就是AutoServiceRegistration接口的实现类
**/
@Bean
@ConditionalOnBean(AutoServiceRegistrationProperties.class)
public NacosAutoServiceRegistration nacosAutoServiceRegistration(
NacosServiceRegistry registry,
AutoServiceRegistrationProperties autoServiceRegistrationProperties,
NacosRegistration registration) {
return new NacosAutoServiceRegistration(registry,
autoServiceRegistrationProperties, registration);
}
}
NacosAutoServiceRegistration 中的 register() 方法开始注册服务,整个调用流程为:
继续追根溯源,这个 registry() 方法是在 AbstractAutoServiceRegistration implements ApplicationListener<WebServerInitializedEvent> 类的 onApplicationEvent() 方法(onApplicationEvent->bind->start->registey) 。
调用的心跳默认5秒一次,具体可参考 BeatReactor 类中的 buildBeatInfo() 方法,其中有个 beatInfo.setPeriod(instance.getInstanceHeartBeatInterval()); 这里获取到一个常量5s。
更加详细的流程可以参考:源码阅读|年轻人可以不讲武德,但是你得会阅读Naocs源码
另外上面最后一步的 NamingClientProxy 接口的实现如下,利用到了委托模式(delegate)也叫代理模式?:
到此这篇关于SpringCloud 服务注册中的nacos实现过程的文章就介绍到这了,更多相关SpringCloud 服务注册nacos内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
原文地址:https://blog.csdn.net/weixin_41866717/article/details/123224101
查看更多关于SpringCloud 服务注册中的nacos实现过程的详细内容...