zoukankan      html  css  js  c++  java
  • springCloud学习-分布式配置中心(Spring Cloud Config)

    1、简介

      Spring Cloud Config :分布式配置中心,方便服务配置文件统一管理,它支持配置服务放在配置服务的内存中(即本地),也支持放在远程Git仓库中。在spring cloud config 组件中,分两个角色,一是config server,二是config client。

    2、config server从本地读取配置文件

      2.1、在父工程的pom.xml中的 <modules>节点下 添加如下代码

         <module>config-server</module>
            <module>config-client</module>

      2.2、创建config-server工程,pom.xml文件如下

    <?xml version="1.0" encoding="UTF-8"?>
    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
        <modelVersion>4.0.0</modelVersion>
    
        <groupId>com.lishun</groupId>
        <artifactId>config-server</artifactId>
        <version>0.0.1-SNAPSHOT</version>
        <packaging>jar</packaging>
    
        <name>config-server</name>
        <description>Demo project for Spring Boot</description>
    
        <parent>
            <groupId>com.lishun</groupId>
            <artifactId>cloud</artifactId>
            <version>1.0-SNAPSHOT</version>
            <relativePath/> <!-- lookup parent from repository -->
        </parent>
    
    
        <dependencies>
             <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-config-server</artifactId>
            </dependency>
        </dependencies>
    
    
    </project>

      2.3、在程序的入口Application类加上@EnableConfigServer注解开启配置服务器的功能,代码如下:

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

      2.4、application.properties配置文件,因为配置文件内容较多,感觉yml格式配置起来不太直观,所以使用.properties格式

    spring.application.name=config-server
    server.port=8888
    
    spring.cloud.config.server.native.search-locations= classpath:/shared
    spring.profiles.active=native

      spring.profiles.active = native指定从本地读取配置,读取的路径为classpath下的shared目录  

      2.5、在工程的 Resources 目录下建个 shared 文件夹,用于存放本地配置文。在 shared 目录下,新建 config-client-dev.properties文件,内容如下

    id  = config-test-native
    name = study-cloud 

    3、构建config-client

      3.1、创建config-server工程,pom.xml文件如下

    <?xml version="1.0" encoding="UTF-8"?>
    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
        <modelVersion>4.0.0</modelVersion>
    
        <groupId>com.lishun</groupId>
        <artifactId>config-client</artifactId>
        <version>0.0.1-SNAPSHOT</version>
        <packaging>jar</packaging>
    
        <name>config-client</name>
        <description>Demo project for Spring Boot</description>
    
        <parent>
            <groupId>com.lishun</groupId>
            <artifactId>cloud</artifactId>
            <version>1.0-SNAPSHOT</version>
            <relativePath/> <!-- lookup parent from repository -->
        </parent>
    
    
        <dependencies>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
            </dependency>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-config</artifactId>
            </dependency>
        </dependencies>
    
    
    </project>

      3.2、配置文件bootstrap.properties。

    spring.application.name=config-client
    spring.cloud.config.uri= http://localhost:8888/
    spring.cloud.config.fail-fast=true
    spring.profiles.active=dev
    server.port=8881

      注意这里是bootstrap.properties,而不是application.properties。bootstrap相对于application具有优先的执行顺序,在配置文件中spring.application.name指明了服务名称,spring.cloud.config.uri指定读取配置文件的路径,

      如果没有读取成功,执行快速失败(fail-fast),spring.profiles.active指明读取的是dev文件,变量 { spring. application.name}和变 spring.profiles.active},两者以“-”相连,构成了向config server读取的配置文件名

      所以这里读取的配置文件是config-client-dev.properties

      3.3、程序的入口类,写一个API接口“/hi”,返回从配置中心读取的id变量的值,代码如下:

    @SpringBootApplication
    @RestController
    public class ConfigClientApplication {
    
        public static void main(String[] args) {
            SpringApplication.run(ConfigClientApplication.class, args);
        }
    
    
        @Value("${id}")
        String id;
        @RequestMapping(value = "/hi")
        public String hi(){
            return id;
        }
    }

      3.4、启动config server 和config client工程,打开网址访问:http://localhost:8881/hi,网页显示:

    config-test-native

    4、从git远程仓库读取配置文件

      4.1、修改config-server的配置文件application.properties,修改内容如下:

    spring.application.name=config-server
    server.port=8888
    
    #spring.cloud.config.server.native.search-locations= classpath:/shared
    #spring.profiles.active=native
    
    spring.cloud.config.server.git.uri=https://github.com/lis-ylfy/config-test/
    spring.cloud.config.server.git.searchPaths=lis
    spring.cloud.config.label=master
    spring.cloud.config.server.git.username=
    spring.cloud.config.server.git.password=
    • spring.cloud.config.server.git.uri:配置git仓库地址
    • spring.cloud.config.server.git.searchPaths:配置仓库路径
    • spring.cloud.config.label:配置仓库的分支
    • spring.cloud.config.server.git.username:访问git仓库的用户名
    • spring.cloud.config.server.git.password:访问git仓库的用户密码

      

      如果Git仓库为公开仓库,可以不填写用户名和密码,如果是私有仓库需要填写,本例子是公开仓库,放心使用。远程仓库 https://github.com/lis-ylfy/config-test/ 中有个文件config-client-dev.properties文件内容如下:

    id  = config-test
    name = study-cloud 

      4.2、重启config server 和config client工程,打开网址访问:http://localhost:8881/hi,网页显示:

    config-test
  • 相关阅读:
    Mybatis原理
    周六上课随记
    第一次外包面试
    复习所想
    如何解决高并发下的超卖问题
    Tomcat架构解析
    即将逝去的25岁
    go 刷算法第一题——反转字符串
    JavaScript杂货
    jdk17新特性
  • 原文地址:https://www.cnblogs.com/shun-gege/p/9501775.html
Copyright © 2011-2022 走看看