Spring Cloud Config为分布式系统中的外部配置提供服务器和客户端支持。使用Config Server,您可以在所有环境中管理应用程序的外部属性。客户端和服务器上的概念映射与Spring Environment和PropertySource抽象相同,因此它们与Spring应用程序非常契合,但可以与任何以任何语言运行的应用程序一起使用。随着应用程序通过从开发人员到测试和生产的部署流程,您可以管理这些环境之间的配置,并确定应用程序具有迁移时需要运行的一切。服务器存储后端的默认实现使用git,因此它轻松支持标签版本的配置环境,以及可以访问用于管理内容的各种工具。很容易添加替代实现,并使用Spring配置将其插入。
新建Spring Boot项目,取名config-server,如果使用IDEA工具构建的话,可以选择Spring Cloud 的Config Server模版,构建好的项目的pom文件如下:
<?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.heyuanjun.config-server</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>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.8.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
<spring-cloud.version>Camden.SR7</spring-cloud.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-server</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka</artifactId>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
<repositories>
<repository>
<id>spring-milestones</id>
<name>Spring Milestones</name>
<url>https://repo.spring.io/milestone</url>
</repository>
<repository>
<id>repository.springframework.maven.snapshot</id>
<name>Spring Framework Maven Snapshot Repository</name>
<url>http://repo.spring.io/snapshot/</url>
</repository>
</repositories>
</project>
给application.property文件添加如下配置:
spring.application.name=config-server
server.port=8888
git仓库地址 spring.cloud.config.server.git.uri=https://github.com/dh1027/SpringcloudConfig #配置仓库路径 spring.cloud.config.server.git.searchPaths=respo
配置仓库的分支
spring.cloud.config.label=master #访问git仓库的用户名(公开仓库不需要用户名密码) spring.cloud.config.server.git.username= #访问git仓库的用户密码 spring.cloud.config.server.git.password
启动类添加注解:@EnableConfigServer。
https://github.com/dh1027/SpringcloudConfig仓库添加一个文件取名config-client-dev.properties,config-client文件配置名称,dev代表环境,可以根据环境不同获取不同的配置文件。文件内容作如下配置,config=version3.
启动项目,浏览器访问:http://localhost:8888/congif/dev,返回数据,
{
“name”: “congif”,
“profiles”: [“dev”],
“label”: “master”,
“version”: “63b35fa6e6e842f6e789eccedb50d8d675bc9ad3”,
“state”: null,
“propertySources”: []
}
name就是文件配置名称。因为仓库中没有congif这个文件名称的配置文件,所以propertySources列表为空。浏览器再访问:http://localhost:8888/config-client/dev
{
“name”: “config-client”,
“profiles”: [“dev”],
“label”: “master”,
“version”: “3a087b60e6367bbf68089ea92546b6e7f1dfeaf2”,
“state”: null,
“propertySources”: [{
“name”: “https://github.com/dh1027/SpringcloudConfig/respo/config-client-dev.properties”,
“source”: {
“config”: “version 3”
}
}]
}
仓库中有config-client-dev.properties文件,并且文件内有配置,所以访问http://localhost:8888/config-client/dev就能得到相应的配置信息。说明配置服务中心成功启动了。
HTTP服务具有以下格式的资源:
/{application}/{profile}[/{label}]
/{application}-{profile}.yml
/{label}/{application}-{profile}.yml
/{application}-{profile}.properties
/{label}/{application}-{profile}.properties
重新构建一个Spring Boot项目,取名config-client,pom文件如下:
<?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.heyaunjun.configclient</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>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.8.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
<spring-cloud.version>Camden.SR7</spring-cloud.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-config</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
<repositories>
<repository>
<id>spring-milestones</id>
<name>Spring Milestones</name>
<url>https://repo.spring.io/milestone</url>
</repository>
<repository>
<id>repository.springframework.maven.snapshot</id>
<name>Spring Framework Maven Snapshot Repository</name>
<url>http://repo.spring.io/snapshot/</url>
</repository>
</repositories>
</project>
配置文件添加以下配置:
spring.application.name=config-client
spring.cloud.config.label=master
spring.cloud.config.profile=dev
spring.cloud.config.uri= http://localhost:8888/
server.port=8881
启动类添加一个接口:
/**
* @author heyuanjun
*/
@SpringBootApplication
@RestController
public class ConfigClientApplication {
public static void main(String[] args) {
SpringApplication.run(ConfigClientApplication.class, args);
}
@Value("${config}")
String foo;
@RequestMapping(value = "/hi")
public String hi(){
return foo;
}
}
启动服务配置中心,启动server-client。浏览器访问http://localhost:8881/hi
说明客户端能远程拿到git仓库中的配置信息。此时到git仓库修改config属性成version 4,浏览器访问http://localhost:8881/hi,获取到的config的值还是version 3,说明配置中心并没有每次都去获取配置属性。这时因为没有添加相应的配置,给客户端添加依赖:
org.springframework.boot
spring-boot-starter-actuator
接口添加注解@RefreshScope,在修改了配置文件的时候,以post请求的方式访问http://localhost:8881/refresh,再请求http://localhost:8881/hi,就可以获取到新的配置的内容。
在生成环境中,可以在提交心新的配置的时候自动调用客户端来更新以保证没次获取到的配置信息都是最新的。例如,github的WebHook:
WebHook是当某个事件发生时,通过发送http post请求的方式来通知信息接收方。Webhook来监测你在Github.com上的各种事件,最常见的莫过于push事件。如果你设置了一个监测push事件的Webhook,那么每当你的这个项目有了任何提交,这个Webhook都会被触发,这时Github就会发送一个HTTP POST请求到你配置好的地址。
如此一来,你就可以通过这种方式去自动完成一些重复性工作,比如,你可以用Webhook来自动触发一些持续集成(CI)工具的运作,比如Travis CI;又或者是通过 Webhook 去部署你的线上服务器
各种IT书籍书目及下载链接
https://blog.csdn.net/dh1027/article/details/89327978