SpringCloud-Config分布式配置

Posted 春天春天

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SpringCloud-Config分布式配置相关的知识,希望对你有一定的参考价值。

概述

  Spring Cloud Config为分布式系统中的外部化配置提供服务器端和客户端支持。使用Config Server,您可以在中心位置管理所有环境中应用程序的外部属性。客户端和服务器上的概念都与Spring EnvironmentPropertySource抽象映射相同,因此它们非常适合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: 3344
spring:
  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

  

@RestController
public 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;
    }
}

 

以上是关于SpringCloud-Config分布式配置的主要内容,如果未能解决你的问题,请参考以下文章

springcloud-Config&Bus&Stream&Sleuth+Zipkin

springcloud-config配置中心初级篇

SpringCloud Config分布式配置中心

SpringCloud 服务配置(Config) 和 服务总线(Bus)

SpringCloud 服务配置(Config) 和 服务总线(Bus)

SpringCloud 服务配置(Config) 和 服务总线(Bus)