一、配置中心提供的核心功能

  Spring Cloud Config为服务端和客户端提供了分布式系统的外部化配置支持。配置服务器为各应用的所有环境提供了一个中心化的外部配置。它实现了对服务端和客户端对Spring Environment和PropertySource抽象的映射

  Spring Cloud Config项目是一个解决分布式系统的配置管理方案。它包含了Client和Server两个部分,server提供配置文件的存储、以接口的形式将配置文件的内容提供出去,client通过接口获取数据、并依据此数据初始化自己的应用。

  Spring cloud使用git或svn存放配置文件,当然他也提供本地化文件系统的存储方式,默认情况下使用git。

二、构建Config Server

  分为三步:

  1.pom.xml中引入spring-cloud-config-server依赖:

<dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-config-server</artifactId></dependency>
</dependencies>

  2.启动类添加@EnableConfigServer注解,激活对配置中心的支持

@EnableConfigServer
@SpringBootApplication
public class ConfigServerApplication {public static void main(String[] args) {SpringApplication.run(ConfigServerApplication.class, args);}
}

  3.配置文件

    Git配置:(开发,测试,生产三份文件)

server:port: 8001
spring:application:name: spring-cloud-config-servercloud:config:server:git:uri: https或ssh     # 配置git仓库的地址search-paths:   # git仓库地址下的相对地址,可以配置多个,用,分割。username:       # git仓库的账号password:       # git仓库的密码

    svn配置: (和git版本稍有区别,需要显示声明subversion.)

server:port: 8001spring:cloud:config:server:svn:uri: username:password:default-label: trunk
  profiles:active: subversionapplication:name: spring-cloud-config-server

    本地存储配置的方式:(只需设置属性)

      spring.profiles.active=native

  Config Server会默认从应用的src/main/resource目录下检索配置文件。也可以通过spring.cloud.config.server.native.searchLocations=file:F:/properties/属性来指定配置文件的位置。

  虽然Spring Cloud Config提供了这样的功能,但是为了支持更好的管理内容和版本控制的功能,还是推荐使用git的方式。

 4.测试:

    github创建了一个springcloudconfigtest目录作为配置仓库,并根据不同环境新建了下面四个配置文件:

  • config-test-dev.properties
  • config-test-test.properties
  • config-test-prod.properties

    为每个配置文件分别设置了testproperties属性赋予不同的值

      如: hello im dev/test/pro   

    测试server端是否可以读取到github上面的配置信息,直接访问:http://localhost:8001/config-test/dev

{"name": "config-test","profiles": ["dev"],"label": null,"version": "","state": null,"propertySources": [{"name": "{git/svn/本地配置地址}dev.yml","source": {"debug": true,"server.port": 8001,"testproperties": "hello im dev" ...//数据源,redis等配置}}]
}

上述的返回的信息包含了配置文件的位置、版本、配置文件的名称以及配置文件中的具体内容,说明server端已经成功获取了git仓库的配置信息。

  直接查看配置文件中的配置信息可访问:http://localhost:8001/config-test-dev.properties,返回:testproperties: hello im dev

   仓库中的配置文件会被转换成web接口,访问可以参照以下的规则:

  • /{application}/{profile}[/{label}]
  • /{application}-{profile}.yml
  • /{label}/{application}-{profile}.yml
  • /{application}-{profile}.properties
  • /{label}/{application}-{profile}.properties

  上面的url会映射{application}-{profile}.properties对应的配置文件,{label}对应git上不同的分支,默认为master。

  如config-test-dev.properties,它的application是config-test,profile是dev。client会根据填写的参数来选择读取对应的配置。

    

  修改配置文件中的配置,并提交,server会自动更新提交的配置

三、微服务客户端(获取server的配置)

  1.添加依赖:spring-cloud-starter-config

<dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-config</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency>
</dependencies>

    引入spring-boot-starter-web包方便web测试

  2.创建启动类

  启动类只需要@SpringBootApplication注解就可以

@SpringBootApplication
public class ConfigClientApplication {public static void main(String[] args) {SpringApplication.run(ConfigClientApplication.class, args);}
}

  3.配置文件

  需要配置两个配置文件,application.yml和bootstrap.yml

  application.yml如下:

spring:application:name: spring-cloud-config-client
server:port: 8002

  bootstrap.properties如下:

spring:cloud:config:        name: "config-test"lab: masteruri: http://localhost:8001/profile: dev

  说明:

  • spring.cloud.config.name:对应{application}部分
  • spring.cloud.config.profile:对应{profile}部分
  • spring.cloud.config.label:对应git的分支。如果配置中心使用的是本地存储,则该参数无用
  • spring.cloud.config.uri:配置中心的具体地址
  • spring.cloud.config.discovery.service-id:指定配置中心的service-id,便于扩展为高可用配置集群。

  特别注意:上面这些与spring-cloud相关的属性必须配置在bootstrap.properties中,config部分内容才能被正确加载。因为config的相关配置会先于application.properties,而bootstrap.properties的加载也是先于application.properties。

  测试:

  使用@Value注解来获取server端参数的值

 @Value("${server端的参数}")private String hello;

  遇到的问题:此时在修改server端的配置文件的参数值,server可以读取到修改后的配置,但是client端读取的值还是旧的

  解决方案:/refresh

    Spring Cloud Config分服务端和客户端,服务端负责将git(svn)中存储的配置文件发布成REST接口,客户端可以从服务端REST接口获取配置。但客户端并不能主动感知到配置的变化,从而主动去获取新的配置。客户端如何去主动获取新的配置信息呢,springcloud已经给我们提供了解决方案,每个客户端通过POST方法触发各自的/refresh

  1.添加依赖

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

  增加了spring-boot-starter-actuator包,spring-boot-starter-actuator是一套监控的功能,可以监控程序在运行时状态,其中就包括/refresh的功能。

  2.开启更新机制

  需要给加载变量的类上面加载@RefreshScope,在客户端执行/refresh的时候就会更新此类下面的变量值。

@RestController
@RefreshScope // 使用该注解的类,会在接到SpringCloud配置中心配置刷新的时候,自动将新的配置更新到该类对应的字段中。

  3.springboot 1.5.X 以上默认开通了安全认证,所以需要在配置文件application.properties添加以下配置

management.security.enabled=false

  tip:可以使用cmd,进行post访问

    curl -X POST http://localhost:8002/refresh

  每次手动刷新客户端也很麻烦,有没有什么办法只要提交代码就自动调用客户端来更新呢,github的webhook是一个好的办法。

  webhook

  参见:http://www.ityouknow.com/springcloud/2017/05/23/springcloud-config-svn-refresh.html

参考:http://www.ityouknow.com/springcloud/2017/05/22/springcloud-config-git.html

   http://blog.didispace.com/springcloud4/

转载于:https://www.cnblogs.com/soul-wonder/p/9214944.html

六、springcloud之配置中心Config相关推荐

  1. springcloud 分布式配置中心 config server config client

    ---------------------------------------------------------------------------------------------------- ...

  2. SpringCloud 分布式配置中心Config Hoxton版本

    Spring Cloud Config简介:Spring Cloud Config为分布式系统提供了服务端和客户端用于支持外部配置.使用Config Server可以在所有环境中管理应用程序的外部属性 ...

  3. Spring Cloud第六章:配置中心Config

    在上一篇文章讲述zuul的时候,已经提到过,使用配置服务来保存各个服务的配置文件.它就是Spring Cloud Config. 一.简介 在分布式系统中,由于服务数量巨多,为了方便服务配置文件统一管 ...

  4. 史上最简单的SpringCloud教程 | 第六篇: 分布式配置中心(Spring Cloud Config)

    转:https://blog.csdn.net/forezp/article/details/70037291 最新版本: 史上最简单的SpringCloud教程 | 第六篇: 分布式配置中心(Spr ...

  5. 搭建SpringCloud配置中心 Config Server

    项目地址: 链接:https://pan.baidu.com/s/1Mxo0ltvZbpz_r8mCU-mSpw  提取码:3j4a 问题解答: SpringCloud Config 分布式配置文件中 ...

  6. iframe的src动态修改并刷新_微服务中配置中心Config+消息总线Bus,实现分布式自动刷新配置

    技术/杨33 一.分布式配置中心Config 一套集中的.动态的配置管理,实现统一配置微服务中的每个子服务. Spring Cloud Config为微服务架构提供了集中化的外部配置支持,配置服务器为 ...

  7. 分布式配置中心-Config

    文章目录 一.常规的配置设置方式 1.传统配置管理的缺点 二.分布式配置中心--Config 1.Config的配置文件命名规则 2.config小demo (1)前期准备 1)创建一个git项目 2 ...

  8. Java B2B2C o2o多用户商城 springcloud架构 (六)分布式配置中心(Spring Cloud Config)

    一.简介 在分布式系统中,由于服务数量巨多,为了方便服务配置文件统一管理,实时更新,所以需要分布式配置中心组件.在Spring Cloud中,有分布式配置中心组件spring cloud config ...

  9. 史上最简单的SpringCloud教程 | 第六篇: 分布式配置中心(Spring Cloud Config)(Finchley版本)...

    转载请标明出处: 原文首发于:https://www.fangzhipeng.com/springcloud/2018/08/30/sc-f6-config/ 本文出自方志朋的博客 在上一篇文章讲述z ...

最新文章

  1. 资源管理器方法访问FTP服务
  2. 【SQL进阶】03.执行计划之旅1 - 初探
  3. Boost:can_require_concepr的使用测试程序
  4. boosting家族之综合理论篇
  5. CoInitialize和CoInitializeEx
  6. Spring 整合 Disruptor 第一个版本
  7. matlab知识集锦
  8. 深入浅出CChart 每日一课——快乐高四第九课 于无声处,CChart内置功能介绍之数据存取篇...
  9. python监控窗口_Windows下python监控脚本
  10. 送给女朋友的情人节礼物---超贴心小程序
  11. vivado下载地址和ISE下载地址
  12. oracle的odac dll,.NET2.0中施用最少的ODAC动态库文件连接Oracle数据库
  13. PAT Basic 1031
  14. 利用有放回抽样估计自然常数e python
  15. xiuno论坛部署及常见问题处理
  16. Electron-开发第一个桌面应用
  17. Aspose.Words 22.12.0 for NET cRACK
  18. Android 获得app的应用签名
  19. web攻防教学防黑客攻击,预防网站攻击
  20. IC设计工程师的职业规划

热门文章

  1. 神经网络—pytorch60min入门教程
  2. idea单行注释对齐修改Settings - Editor - Code Style-Code Generation,取消comment code的勾选
  3. 8086汇编贪吃蛇(随机食物+速度递增)
  4. 1.确保容器中的对象拷贝正确而高效
  5. Linux watch命令详解
  6. c++ primer第四版上的内容质疑
  7. C++文件操作之get/getline(待学)
  8. socket网络编程——网络编程接口
  9. java怎样实现自定义过滤关键词_SpringSecurity学习之自定义过滤器的实现代码
  10. 数据挖掘方法案例介绍