SpringCloud-Config分布式配置代码示例

时间:2021-05-20

概述

Spring Cloud Config为分布式系统中的外部化配置提供服务器端和客户端支持。使用Config Server,您可以在中心位置管理所有环境中应用程序的外部属性。客户端和服务器上的概念都与Spring Environment和PropertySource抽象映射相同,因此它们非常适合Spring应用程序,但可以与以任何语言运行的任何应用程序一起使用。

在应用程序从开发人员到测试人员再到生产人员的整个部署过程中,您可以管理这些环境之间的配置,并确保应用程序具有它们迁移时所需的一切。服务器存储后端的默认实现使用git,因此它轻松支持带标签的配置环境版本,并且可以通过各种工具来访问这些内容来管理内容。添加替代实现并将其插入Spring配置很容易。

•去码云创建仓库,克隆到本地文件夹,配置application.yml文件

  •application.yml配置

spring: profiles: active: dev---spring: profiles: dev application: name: springcloud-config-dev---spring: profiles: test application: name: springcloud-config-test

  •把这个文件提交到码云上,总共四步。

  第一步:

    把文件添加到暂存区    

git add

   在这里添加

    第二步:

      查看状态

git status

   第三步:

提交

git commit -m "fist commit" //fist commit是描述信息

   第四步:

      push到远程

git push origin master

   测试:成功

 •创建服务端Server项目

  •导入依赖

<dependencies> <!--config--> <!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-config-server --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-config-server</artifactId> <version>2.1.1.RELEASE</version> </dependency> <!--actuator完善监控信息--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> </dependencies>

  •编写配置

server: port: 3344spring: application: name: springcloud-congi-server #连接远程仓库 cloud: config: server: git: uri: https://gitee.com/springandspring/springcloud-config.git #这里的uri是码云上自己创建的仓库HTTPS下载的地址

  •开启功能

@EnableConfigServer

  •测试

  •更上面一样

  •config-client配置

spring: profiles: active: dev---server: port: 8201#spring的配置spring: profiles: dev application: name: springcloud-provider-dept#Eureka的配置,服务注册到哪里eureka: client: service-url: defaultZone: http://eureka7001.com:7001/eureka/---server: port: 8202#spring的配置spring: profiles: test application: name: springcloud-provider-dept#Eureka的配置,服务注册到哪里eureka: client: service-url: defaultZone: http://eureka7001.com:7001/eureka/

  •执行上面的四步,push到远程

  •创建一个client客户端新项目

  •导入依赖

<dependencies> <!--config--> <!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-config --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-config</artifactId> <version>2.1.1.RELEASE</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> </dependencies>

  •编写bootstrap配置  

#系统级别的配置 比用户级别设置先执行spring: cloud: config: profile: dev #生产环境 name: config-client #需要从git上读取的资源名称,不需要后缀 label: master uri: http://localhost:3344 #连接服务端的地址 #相当于http://localhost:3344/master/config-client-dev/master

  编写application配置

#用户级别的设置spring: application: name: springcloud-config-client-3355

  •编写启动类

 •编写Controller

@RestControllerpublic class ConfigClientController { @Value("${spring.application.name}") private String applicationName; @Value("${eureka.client.service-url.defaultZone}") private String eurekaServer; @Value("${server.port}") private String port; @RequestMapping("/config") //请求这个路径获取config-client配置里面的信息 public String getConfig(){ return "applicationName"+applicationName+ "eurekaServer"+eurekaServer+ "port"+port; }}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章