本文主要是介绍【Spring Cloud】SpringCloud接入SOFARegistry,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
背景
由于项目开发使用的是SpringCloud,但是甲方使用的是阿里云提供的私有云注册中心,需要替换注册中心。
方案
官方文档:Spring Cloud 使用 SOFARegistry
改造的步骤:
1.去掉原项目中注册中心的pom依赖引入,我们使用的Nacos
<!--Nacos 注册中心-->
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId><exclusions><exclusion><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-ribbon</artifactId></exclusion></exclusions>
</dependency>
2.引入官方提供的pom,当前最新版本为1.2.8
<dependency><groupId>com.alipay.sofa</groupId><artifactId>sofa-registry-cloud-all</artifactId><!-- 替换 x.x.x 为该 SDK 最新版本号 --><version>1.2.8</version>
</dependency>
3.启动配置增加,例如application.yml
sofa:registry:discovery:instanceId: //当前登录账号的实例 ID。antcloudVip: //当前地域的 ACVIP 地址值。accessKey: //当前登录账号的 AccessKey ID。secretKey: //当前登录账号的 AccessKey Secret。
注意: instanceId是一个固定的值,我理解类似于Nacos的namespace,由于当时我们理解错了instanceId,我们当时理解为就是一个实例id,约等于spring.application.name。所以一度导致服务注册不了。
4.官网提示的trace和healthCheck是否可以接入
<!-- 接入tracer -->
<!-- for Spring Boot 2.X -->
<dependency><groupId>com.alipay.sofa</groupId><artifactId>tracer-enterprise-sofa-boot-starter</artifactId><version>3.2.3.JST.1</version><exclusions><exclusion><groupId>com.alipay.sofa.common</groupId><artifactId>sofa-common-tools</artifactId></exclusion><exclusion><groupId>com.alipay.sofa</groupId><artifactId>tracer-enterprise-dst-plugin</artifactId></exclusion></exclusions>
</dependency>
<dependency><groupId>com.alipay.sofa.common</groupId><artifactId>sofa-common-tools</artifactId><version>1.0.17</version>
</dependency>
当然是不行的对于我们的项目,正如官网描述的这样:Finchley、Greenwich 版本(对应 Spring Boot 2.x 版本)
由于我们的SpringCloud版本是2020.x.x是无法和上面的trace兼容,tracer-enterprise-sofa-boot-starter使用的负载是ribbion,但是高版本的Spring Cloud使用的loadbalance是
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-loadbalancer</artifactId></dependency>
因此,不兼容。
这篇关于【Spring Cloud】SpringCloud接入SOFARegistry的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!