七、SpringCloud Config分布式配置中心
1 背景
分布式系统环境下,将单体应用中的业务拆分成各个子服务,每个服务的粒度相对较小,因此整个系统中会出现大量的微服务。每个微服务都需要必要的配置信息才能运行,因此一套集中式、动态的配置管理设施是必不可少的。
每个微服务都有自己的配置文件application.yml或application.properties,SpringCloud Config为微服务架构中的各个微服务提供集中化的外部配置支持。其中,配置服务器ConfigServer为各个不同的微服务应用环境提供了一个中心化的外部配置平台,统一管理、配置各个微服务的配置文件。
2 概念
SpringCloud Config分为服务端与客户端两部分。
- 服务端Server:也称为分布式配置中心,它是一个独立的微服务应用,用来连接配置服务器并为客户端提供获取配置信息、加解密信息等访问接口。
- 客户端Client:通过指定的配置中心来管理应用资源,及业务相关的配置内容,并在启动时从配置中心获取和加载配置信息。配置服务器默认采用git来存储配置信息,这样就有助于对环境配置进行版本管理,且可通过git客户端来方便的管理和访问配置信息内容。
3. SpringCloud Config服务端配置
3.1 在github上新建仓库
- 登录GitHub:
https://github.com/
,新建一个仓库:
- 输入仓库名称:
springcloud-demo-config
权限可以是Public(公开),也可以是Private(私有),我这里就暂时选择私有。
这里可以看到仓库地址,可供外界通过HTTPS与SSH两种方式访问。
3.2 在本地新建仓库并克隆
配置git这里不作阐述。 我这里已经配置好了git,直接演示效果。
- 在本地目录:H:\develop\config中克隆刚才的仓库,打开git操作命令行(Git Bash Here):
- 测试github是否成功连接,由于我在github中已经配置了SSH keys,因此这里显示成功:
ssh -T git@github.com
- 克隆仓库,我这里使用SSH方式,因为设置SSH key时没有设置密码,直接拉取比较方便:
git clone git@github.com:SuperCNJ/springcloud-demo-config.git
- 进入git目录springcloud-demo-config,发现本地仓库建立完成:
git status
3.3 新建配置文件并上传
- 在springcloud-demo-config目录下新建配置文件application.yml,设置各个环境下的应用名称,并指定当前选定环境,注意文件保存为UTF-8格式,否则推送到github会报错。
spring:
profiles:
active: dev
---
spring:
profiles: dev #开发环境
application:
name: springcloud-demo-dev
---
spring:
profiles: test #测试环境
application:
name: springcloud-demo-test
---
spring:
profiles: prod #生产环境
application:
name: springcloud-demo-prod
- 将新添加的文件上传至github
git status
可看到当前有未提交文件application.yml
git add .
将当前目录下的所有文件添加到暂存区
git commit -m "init file"
暂存区的文件提交到本地仓库,给定message为“init file”
git push origin master
将文件从本地仓库推送至github,分支为master
- 推送成功,可在github上查看:
3.4 新建模块并完成配置
- 在工程spring-cloud-demo下,新建模块config-server-5001。该模块为config server,负责与github通信。
- 修改POM文件,添加
spring-cloud-config-server
依赖
<dependencies>
<!-- springCloud Config -->
<dependency>