一塊兒來學Spring Cloud | 第七章:分佈式配置中心(Spring Cloud Config)

上一章節,咱們講解了服務網關zuul,本章節咱們從git和本地兩種存儲配置信息的方式來說解springcloud的分佈式配置中心-Spring Cloud Config。html

1、Spring Cloud Config簡介:java

Spring Cloud Config項目是一個解決分佈式系統的配置管理方案。它包含了Client和Server兩個部分,server提供配置文件的存儲、以接口的形式將配置文件的內容提供出去,client經過接口獲取數據、並依據此數據初始化本身的應用。mysql

2、新建springcloud-config-server模塊:git

1. 參考:一塊兒來學Spring Cloud | 第一章 :如何搭建一個多模塊的springcloud項目 來新建一個基本模塊結構github

2. 修改pom.xml中引入依賴web

<?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>

	<parent>
		<groupId>com.haly</groupId>
		<artifactId>springcloud</artifactId>
		<version>0.0.1-SNAPSHOT</version>
	</parent>

	<groupId>com.haly</groupId>
	<artifactId>springcloud-config-server</artifactId>
	<version>0.0.1-SNAPSHOT</version>
	<name>springcloud-config-server</name>
	<description>新建一個config server項目</description>

	<dependencies>
		<dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>
        <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>

	<build>
		<plugins>
			<plugin>
				<groupId>org.springframework.boot</groupId>
				<artifactId>spring-boot-maven-plugin</artifactId>
			</plugin>
		</plugins>
	</build>
	
</project>

3. 新建入口啓動類SpringcloudConfigServerApplicationredis

@EnableConfigServer,表示開啓Config Serverspring

package com.haly;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.config.server.EnableConfigServer;

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

}

4. 修改application.properties文件(git方法存儲配置)sql

在Github上建立一個項目,並在上面添加配置文件config-client.properties,配置文件裏添加一個屬性config=NewConfig !apache

application.properties中配置服務信息以及git信息

spring.application.name=springcloud-config-server
server.port=7001
eureka.client.serviceUrl.defaultZone=http://localhost:8761/eureka/

spring.cloud.config.server.git.uri=https://github.com/FunriLy/springcloud-study/
spring.cloud.config.server.git.searchPaths=config-repo
spring.cloud.config.server.git.username=Username
spring.cloud.config.server.git.password=Password

啓動工程 Config Server,瀏覽器輸入:http://localhost:7001/config-client/default/master,獲得結果以下

{
    "name": "config-client",
    "profiles": [
        "default"
    ],
    "label": null,
    "version": "52b88000fc46a8b1d72a2979f4721d45a3d1f429",
    "state": null,
    "propertySources": [
        {
            "name": "https://github.com/FunriLy/springcloud-study//config-repo/config-client.properties",
            "source": {
                "configword": "NewConfig !"
            }
        }
    ]
}

3、新建springcloud-config模塊(可不要):

其實我在工做中喜歡建立一個springcloud-config模塊,沒有業務代碼,只有pom.xml文件和resources目錄,resources放一下公共的配置文件,能夠給其它模塊引用

例如配置:

spring-data-mysql.xml 文件

spring-data-redis-single.xml 文件

spring-jdbc-mysql.xml 文件

bootstrap.yml 配置文件

1. 新增pom.xml文件

<?xml version="1.0"?>
<project
        xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
        xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>com.sinaif</groupId>
        <artifactId>sinaif-weibo-opt</artifactId>
        <version>1.0.0-SNAPSHOT</version>
        <relativePath>../pom.xml</relativePath>
    </parent>

    <groupId>com.sinaif</groupId>
    <artifactId>sinaif-config</artifactId>
    <name>${project.artifactId}</name>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    </properties>
    <dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>
    <build>
        <resources>
            <resource>
                <directory>src/main/resources</directory>
                <filtering>true</filtering>
            </resource>
        </resources>
    </build>
</project>

2. 新增bootstrap.yml文件(能夠統一配置config,eureka ,hystrix等待)

注意這裏是bootstrap.properties而不是appliction.properties由於bootstrap.properties會在應用啓動以前讀取,而spring.cloud.config.uri會影響應用啓動

spring:
    cloud:
        config:
            name: config-client
            profile: default
            label: master
            uri: http://localhost:7001/
            
eureka:
    client:
        serviceUrl:
            defaultZone: http://localhost:8761/eureka/
    

上面配置config屬性的規則,以及前面咱們直接用 http://localhost:7001/config-client/default/master 訪問配置的規則

URL與配置文件的映射關係

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

application是config-client-dev.properties文件中的config-client值,profile是一個active的profile,通常用來表示環境信息,label是一個可選的標籤,通常用來表示目錄名稱。
好比,我在Github上的文件名是config-client.properties,在Github上都是default環境,默認爲master分支。因此就是/config-client/default/master

4、新建springcloud-config-server 的client模塊:

我用以前寫過的springcloud-feign-client模塊,在FeignController類裏增長一個/testconfig方法充當Client端,springcloud-feign-client模塊內容參考:一塊兒來學Spring Cloud | 第四章:服務消費者 ( Feign )

1. 在pom.xml文件中,增長上面新建的模塊的依賴包,這樣咱們就能使用springcloud-config模塊中的eureka和config配置

 <dependency>
            <groupId>com.haly</groupId>
            <artifactId>springcloud-config</artifactId>
            <version>0.0.1-SNAPSHOT</version>
  </dependency>

2. 在FeignController類中增長一個測試方法

@Value("${configword}")
String configword;

@GetMapping(value = "/testconfig") public String testconfig(@RequestParam String name) {
return name +",git配置值:" + configword ;

}

3.  啓動服務,進行測試

依次啓動springcloud-eureka-server模塊,啓動springcloud-config-server模塊,啓動springcloud-feign-client模塊

訪問:http://localhost:9600/testconfig?name=young碼農,返回結果 :

young碼農,git配置值:NewConfig !

5、使用本地配置獲取配置項:

1. 修改springcloud-config-server模塊中的application.properties配置以下 

spring.application.name=springcloud-config-server
server.port=7001
eureka.client.serviceUrl.defaultZone=http://localhost:8761/eureka/

# 表示使用本地config配置
spring.profiles.active=native
# 表示本地配置讀取的目錄文件位置
spring.cloud.config.server.native.searchLocations: classpath:/config/

2. 在springcloud-config-server模塊resources目錄下新建一個config文件,在config文件下新建2個配置文件,配置項內容以下:

configs-dev.properties:configword: dev-configword

configs-test.properties:configword: test-configword

3. 修改springcloud-config模塊的bootstrap.yml配置文件的config配置

ps: 目前咱們設置的profile爲dev,因此會從configs-dev.properties配置文件中讀取數據

spring:
    cloud:
        config:
            name: configs
            profile: dev
            label: config
            uri: http://localhost:7001/
            
eureka:
    client:
        serviceUrl:
            defaultZone: http://localhost:8761/eureka/

4. 啓動服務,運行結果

依次啓動springcloud-eureka-server模塊,啓動springcloud-config-server模塊,啓動springcloud-feign-client模塊

先訪問config-server,瀏覽器輸入:http://localhost:7001/configs/dev/config

{
    "name": "configs",
    "profiles": [
        "dev"
    ],
    "label": "config",
    "version": null,
    "state": null,
    "propertySources": [
        {
            "name": "classpath:/config/configs-dev.properties",
            "source": {
                "configword": "dev-configword"
            }
        }
    ]
}

在訪問config-client,瀏覽器輸入:http://localhost:9600/testconfig?name=young碼農,返回結果以下:

young碼農,git配置值:dev-configword

5. 修改springcloud-config模塊的bootstrap.yml配置文件的profile屬性:

ps: 目前咱們設置的profile爲dev,因此會從configs-test.properties配置文件中讀取數據

spring:
    cloud:
        config:
            name: configs
            profile: test
            label: config
            uri: http://localhost:7001/        

6.  再次啓動服務,運行結果

依次啓動springcloud-eureka-server模塊,啓動springcloud-config-server模塊,啓動springcloud-feign-client模塊

先訪問config-server,瀏覽器輸入:http://localhost:7001/configs/dev/config

{
    "name": "configs",
    "profiles": [
        "test"
    ],
    "label": "config",
    "version": null,
    "state": null,
    "propertySources": [
        {
            "name": "classpath:/config/configs-test.properties",
            "source": {
                "configword": "test-configword"
            }
        }
    ]
}

在訪問config-client,瀏覽器輸入:http://localhost:9600/testconfig?name=young碼農,返回結果以下:

young碼農,git配置值:test-configword

相關文章
相關標籤/搜索