SpringCloud Config配置中心

Config入门

什么是springcloud config?

SpringCloud Config为微服务架构中的微服务提供集中化的外部配置支持,配置服务器为各个不同微服务应用的所有环境提供了一个中心化的外部配置。

SpringCloud Config分为服务端和客户端两部分。将配置信息以REST接口的形式暴露。

服务端也称为分布式配置中心,它是一个独立的微服务应用,用来连接配置服务器并为客户端提供获取配置信息,加密/解密信息等访问接口

客户端则是通过指定的配置中心来管理应用资源,以及与业务相关的配置内容,并在启动的时候从配置中心获取和加载配置信息配置服务器默认采用git来存储配置

信息,这样就有助于对环境配置进行版本管理,并且可以通过git客户端工具来方便的管理和访问配置内容。

官网

Spring Cloud Config

config服务端

  1. 在父工程下创建cloud-config-center-3344

  2. 创建完成后修改pom文件

            
                org.springframework.cloud
                spring-cloud-config-server
            
  3. 创建application.yml

    server:
      port: 3344
    ​
    spring:
      application:
        name:  cloud-config-center #注册进Eureka服务器的微服务名
      cloud:
        config:
          server:
            git:
              uri: [email protected]:zzyybs/springcloud-config.git #GitHub上面的git仓库名字
            ####搜索目录
              search-paths:
                - springcloud-config
          ####读取分支
          label: master
    ​
    #服务注册到eureka地址
    eureka:
      client:
        service-url:
          defaultZone: http://localhost:7001/eureka
    ​

  4. 创建主启动类

    @SpringBootApplication
    @EnableConfigServer    // 支持springcloud config的注解
    public class ConfigCenterMain3344
    {
        public static void main(String[] args) {
                SpringApplication.run(ConfigCenterMain3344.class, args);
        }
    }

config客户端

  1. 在父工程下创建cloud-config-client-3355

  2. 创建完成后修改pom文件

            
                org.springframework.cloud
                spring-cloud-starter-config
            
  3. 创建bootstrap.yml

    server:
      port: 3355
    ​
    spring:
      application:
        name: config-client
      cloud:
        #Config客户端配置
        config:
          label: master #分支名称
          name: config #配置文件名称
          profile: dev #读取后缀名称   上述3个综合:master分支上config-dev.yml的配置文件被读取http://config-3344.com:3344/master/config-dev.yml
          uri: http://localhost:3344 #配置中心地址k
    ​
    #服务注册到eureka地址
    eureka:
      client:
        service-url:
          defaultZone: http://localhost:7001/eureka
    ​
    ​

    applicaiton.yml是用户级的资源配置项 bootstrap.yml是系统级的,优先级更加高

    Spring Cloud会创建一个“Bootstrap Context”,作为Spring应用的Application Context的父上下文。初始化的时候,Bootstrap Context负责从外部源加载配置属性并解析配置。这两个上下文共享一个从外部获取的Environment

    Bootstrap属性有高优先级,默认情况下,它们不会被本地配置覆盖。 Bootstrap contextApplication Context有着不同的约定,所以新增了一个bootstrap.yml文件,保证Bootstrap ContextApplication Context配置的分离。

    要将Client模块下的application.yml文件改为bootstrap.yml,这是很关键的, 因为bootstrap.yml是比application.yml先加载的。bootstrap.yml优先级高于application.yml

  4. 创建主启动类

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

Config客户端之动态刷新

  1. 避免每次更新配置都要重启客户端微服务3355,修改3355模块

  2. pom引入监控依赖

    
        org.springframework.boot
        spring-boot-starter-actuator
    

  3. 修改yml,暴露监控端点

    server:
      port: 3355
    ​
    spring:
      application:
        name: config-client
      cloud:
        #Config客户端配置
        config:
          label: master #分支名称
          name: config #配置文件名称
          profile: dev #读取后缀名称   上述3个综合:master分支上config-dev.yml的配置文件被读取
          uri: http://localhost:3344 #配置中心地址k
    ​
    #服务注册到eureka地址
    eureka:
      client:
        service-url:
          defaultZone: http://localhost:7001/eureka
    # 暴露监控端点
    management:
      endpoints:
        web:
          exposure:
            include: "*"

  4. 业务类添加刷新注解

    @RestController
    @RefreshScope    //支持刷新注解
    public class ConfigClientController
    {
        @Value("${config.info}")
        private String configInfo;
    ​
        @GetMapping("/configInfo")
        public String getConfigInfo() {
            return configInfo;
        }
    }

  5. 发送post请求刷新 curl -X POST "http://localhost:3355/actuator/refresh"

你可能感兴趣的:(springcloud,微服务)