这篇文章主要介绍了SpringCloud服务注册中的nacos怎么实现的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇SpringCloud服务注册中的nacos怎么实现文章都会有所收获,下面我们一起来看看吧。
如下图,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.com" 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。
另外上面最后一步的NamingClientProxy接口的实现如下,利用到了委托模式(delegate)也叫代理模式?:

关于“SpringCloud服务注册中的nacos怎么实现”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“SpringCloud服务注册中的nacos怎么实现”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注亿速云行业资讯频道。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。