分布式系统中,服务数量剧增,其配置文件须要实现统一管理而且可以实时更新,分布式配置中心组件必然是须要的。Spring Cloud提供了配置中心组件Spring Cloud Config ,它支持配置服务放在远程Git仓库和本地文件中。默认采用git来存储配置信息,笔者示例也是采用默认的git repository,这样经过git客户端工具来方便的管理和访问配置内容。html
在Spring Cloud Config 组件中,有两个角色,一是Config Server配置服务器,为其余服务提供配置文件信息;另外一个是Config Client即其余服务,启动时从Config Server拉取配置。
下面分别介绍下Config Server和Config Client的搭建实现方法。java
只须要添加以下两个jar包的引用。git
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-server</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-consul-discovery</artifactId>
<exclusions>
<exclusion>
<artifactId>jsr311-api</artifactId>
<groupId>javax.ws.rs</groupId>
</exclusion>
</exclusions>
</dependency>
</dependencies>复制代码
由于Spring Cloud Config服务器为客户端提供配置是要经过服务发现,因此这边引入consul的starter,配置服务器和客户端都注册到consul集群中。github
简单,由于Spring Cloud 提供了不少开箱即用的功能,经过spring-cloud-config-server的注解激活配置服务器。spring
@SpringBootApplication
@EnableDiscoveryClient
@EnableConfigServer
public class ConfigServerApplication {
public static void main(String[] args) {
SpringApplication.run(ConfigServerApplication.class, args);
}
}复制代码
@EnableConfigServer
注解很重要,将该服务标注为配置服务器;@EnableDiscoveryClient
注册服务,供其余服务发现调用。bootstrap
server:
port: 8888
spring:
application:
name: config-server
cloud:
consul:
discovery:
preferIpAddress: true
enabled: true
register: true
service-name: config-service
//...
host: localhost
port: 8500
---
spring:
cloud:
config:
server:
git:
uri: https://gitee.com/keets/Config-Repo.git
searchPaths: ${APP_LOCATE:dev}
username: user
password: pwd复制代码
配置第一段指定了服务的端口;第二段是服务发现相关的配置;第三段是配置服务器的信息,这里将配置文件存储在码云上,默认的搜索文件路径为dev文件夹,能够经过环境变量指定,再下面是用户名和密码,公开的项目不须要设置用户名和密码。api
至此配置服务器已经搭建完成,是否是很简单?服务器
配置服务器配置的仓库是https://gitee.com/keets/Config-Repo.git
。笔者在这个仓库中建了两个文件夹:dev和prod。而且在dev文件夹中新建了文件configclient-dev.yml。为何这样命名,能随便命名吗?答案是不能够,下面咱们看下config文件的命名规则。微信
URL与配置文件的映射关系以下:app
spring.application:configclient
,exp对应{profile},{label}不指定则默认为master。新建的configclient-dev.yml以下:
spring:
profiles: dev
cloud:
version: Dalston.SR4复制代码
只须要添加以下两个jar包的引用。
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-server</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-consul-discovery</artifactId>
<exclusions>
<exclusion>
<artifactId>jsr311-api</artifactId>
<groupId>javax.ws.rs</groupId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
</dependencies>复制代码
新增spring-boot-starter-actuator监控模块,为了配置信息是动态刷新,其中包含了/refresh刷新API。其余和配置服务器中添加的相同,没啥可说。
简单,由于Spring Cloud 提供了不少开箱即用的功能,经过spring-cloud-config-server的注解激活配置服务器。
@SpringBootApplication
@EnableDiscoveryClient
public class ConfigServerApplication {
public static void main(String[] args) {
SpringApplication.run(ConfigServerApplication.class, args);
}
}复制代码
配置客户端不须要@EnableConfigServer
注解。
server:
port: 9901
cloud:
version: Brixton SR7
spring:
cloud:
consul:
discovery:
preferIpAddress: true
enabled: true
register: true
service-name: config-client
//...
host: localhost
port: 8500
---
spring:
profiles:
active: dev
application:
#app名称
name: configclient
cloud:
config:
#指定profile
profile: dev
label: master
discovery:
enabled: true
#server名
service-id: config-service
enabled: true
fail-fast: true
---
spring:
profiles: default
application:
name: configclient复制代码
从上面配置能够看出咱们所激活的profile是dev,配置的配置服务名为config-service
,指定从master分支拉取配置。因此configclient启动时会去配置服务器中拉取对应的configclient-dev的配置文件信息。
笔者新建了一个TestResource,对应的API端点为/api/test。
@Value("${cloud.version}")
private String version;
@GetMapping("/test")
public String from() {
return version;
}复制代码
cloud.version
能够在上面的配置文件看到默认指定的是Brixton SR7,而笔者在配置中心设置的值为Dalston.SR4。
首先看一下配置客户端启动时的日志信息,是否是真的按照咱们配置的,从配置服务器拉取configclient-dev信息。
从日志看来,是符合的上面的配置猜测的。咱们再从配置客户端提供的API接口进一步验证。
能够看到确实是Dalston.SR4,配置服务可以正常运行。
Spring Cloud Config还能够实现动态更新配置的功能。下面咱们修改下Config Repo中的cloud.version配置为Camden SR7,并经过刷新config client的/refresh端点来应用配置。
从下图能够看到结果是预期所想。
这边配置的刷新是经过手工完成了,还能够利用githook进行触发。当本地提交代码到git后,调用了下图设置的url。有两个端点可使用:
第二种状况比较耗时,@RefreshScope
是spring cloud提供的注解,在执行refresh时会刷新bean中变量值。下面看一下源码上的解释。
Convenience annotation to put a @Bean definition in RefreshScope.
Beans annotated this way can be refreshed at runtime and any components that are using them will get a new instance on the next method call, fully initialized and injected with all dependencies.
上面大意是RefreshScope是一个方便的bean注解,加上这个注解能够在运行态刷新bean。其余使用该bean的components下次调用时会获取一个被初始化好的新实例对象。
githook设置页面以下。
本文主要讲了配置服务器和配置客户端的搭建过程,最后经过配置客户端的日志和端点信息验证是否能成功使用配置服务中心。整体来讲,很是简单。文中的部分配置没有写完整,读者须要能够看文末的git项目。
不过关于配置中心,本文的讲解并不完整,下一篇文章将会讲解配置服务器与消息总线的结合使用,实现对配置客户端的自动更新及灰度发布等功能。
本文源码
github: github.com/keets2012/S…
gitee: gitee.com/keets/sprin…