一、什么是spring cloud config
1.Spring Cloud Config的作用
在微服务架构系统中,有大量的应用分布在不同机器或容器中运行,如何方便统一的管理这些应用的配置信息是一个不小的挑战,spring cloud config就是用来解决这个问题的.spring cloud config同时包含服务端和客户端支持,其中服务端对应一个配置中心来管理所有应用的外部配置,客户端通过服务端来从配置中心获取自己应用对应的配置信息。无论是服务端还是配置端主要的原理都是把配置信息映射到Environment 和 PropertySource,所以spring cloud config能很好的和spring应用结合起来。
2.Spring Cloud Config架构图(git)
3.架构说明
- ⑴ 通过git操作上传、修改配置文件
- ⑵ config server 模块将git上最新的信息同步到自己的Environment中
- ⑶ 通过发送post请求触发客户端刷新自己的配置信息(可以在git中追加webhooks来自动实现)
- ⑷ 客户端接收到post请求后重新从config server中拉取自己对应的配置信息
二、如何使用spring cloud config
1.官方demo例子
2. 如何使用官方例子(基于git版简单说明)
- ⑴ 工程介绍
① configuration-service:服务端,负责从GIT仓库中获得配置信息
② configuration-client:客户端,即我们的应用程序,从server端获取配置信息
- ⑵ server端配置
- ⑶ client端配置
- ⑷ git仓库配置
- ⑸ git webhooks配置
三、制作server端docker镜像
1.编辑Dockerfile
#基础镜像基于openjdk,利用alpine
FROM openjdk:8-jre-alpine
#所属团队
MAINTAINER chengaofeng
#编译时变量
ARG TARGET_JAR
ENV TARGET_JAR ${TARGET_JAR:-spring-configuration-server-0.0.1-SNAPSHOT.jar}
# git用户和密码
ENV GIT_USERNAME=chengaofeng GIT_PASSWORD=admin222
# 中心化配置git工程URI
ENV GIT_URI=http://192.168.0.104/chengf/config.git
ENV PORT=8888
#将编译好的工程jar包copy到镜像容器中
COPY target/${TARGET_JAR} /usr/src/${TARGET_JAR}
#设置工作目录
WORKDIR /usr/src
#程序入口
CMD java -jar ${TARGET_JAR} --server.port=${PORT} --spring.cloud.config.server.git.uri=${GIT_URI} --spring.cloud.config.server.git.username=${GIT_USERNAME} --spring.cloud.config.server.git.password=${GIT_PASSWORD}
2. 编译镜像,Dockerfile在server工程根目录
docker build -t config-server .
3. 启动镜像
docker run –d -p 8888:8888 config-server
如果git仓库地址变动,或者用户名、密码变更利用对应的启动参数,例如当git仓库地址变更时:
docker run –d -p 8888:8888 -e GIT_URI="http://www.domain.com/production/config.git" config-server
四、config-server基于本地文件
配置文件:
---
spring:
cloud:
config:
server:
native:
searchLocations: classpath:/config
server:
port: 8888
client需要的配置文件放在 classpath下的config目录中,仍旧是用appName来做区分
如:
client-server1.yml
client-server2.yml
- 大小: 31.3 KB
- 大小: 44.9 KB
- 大小: 43.4 KB
- 大小: 33.2 KB
- 大小: 47.6 KB
分享到:
相关推荐
1.Spring Cloud Config 用于为分布式系统中的基础设施和微服务应用提供集中化的外部配置支持,分为服务端和客户端。 2.服务端为分布式配置中心,是一个独立的微服务应用;客户端为分布式系统中的基础设置或微服务...
spring cloud config/bus源码解读,,包含server端,client端,bus的运行原理
Spring Cloud Config(本地配置中心或git配置中心)搭建源码
一个关于Spring Cloud Config的简单Demo,解压后用idea打开即可
《深入理解Spring Cloud与微服务构建》学习笔记(二十)~配置中心Spring Cloud Config
spring cloud config 代码示例,详细见http://www.cnblogs.com/shamo89/p/8016908.html
SpringCloud——分布式配置中心(Spring Cloud Config)之高可用的分布式配置中心
Spring Cloud Bus配合Spring Cloud Config使用可以实现配置的动态刷新 spring cloud bus能管理和传播分布式系统间的消息,就像分布式执行器,可用于广播状态更改、时间推送等,也可以当做微服务间的通信通道 spring ...
spring cloud中文版【Spring Cloud Config】--spring cloud中文文档
springcloud config配置中心
Spring Cloud Config技术分享,讲解实战Spring Cloud Config的配置及部署环境
spring-cloud-config是用来集中管理分布式的配置问题,不同环境不同配置,动态化的配置更新,分环境部署比如dev/test/prod/beta/release,运行期间动态调整配置,不再需要在每个服务部署的机器上编写配置文件,服务...
spring cloud config client 服务配置中心 客户端 http://knight-black-bob.iteye.com/blog/2356532
springcloud config分布式配置中心,需要注意gitee上创建的文件格式,特别注意不然 config client启动的时候就会报错误 说@value("${name}")的值找不到
spring cloud config微服务配置中心
根据需求,自动刷新springcloud config 中心的 配置,完整示例代码,可以运行起来
Spring Cloud Config刷新目录Spring Cloud Config自动刷新1.特点从Spring Cloud Config Server添加可配置的“自动”配置功能,并具有可配置的延迟。2.设定为了设置刷新,您必须将休闲依存关系添加到Cloud Config ...
Spring Cloud Config模块