当前位置:   article > 正文

【Spring Cloud】SpringCloud接入SOFARegistry

【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>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

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>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

3.启动配置增加,例如application.yml

sofa:
  registry:
    discovery:
        instanceId:          //当前登录账号的实例 ID。
        antcloudVip:       //当前地域的 ACVIP 地址值。
        accessKey:           //当前登录账号的 AccessKey ID。
        secretKey:           //当前登录账号的 AccessKey Secret。
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

注意: 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>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22

当然是不行的对于我们的项目,正如官网描述的这样: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>

  • 1
  • 2
  • 3
  • 4
  • 5

因此,不兼容。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/很楠不爱3/article/detail/301487
推荐阅读
相关标签
  

闽ICP备14008679号