SpringCloud全家桶学习之分布式配置中心----Config(七)
一、概述
(1)背景
微服务意味着将单体应用中的业务拆分成一个个子服务,每个服务的粒度相对较小,因此系统中出现大量的服务。由于每个服务都需要配置必要的配置信息才能运行,所以一套集中式的、动态的配置管理设施是必不可少的。Spring Cloud提供了ConfigServer来解决这个问题,我们每一个微服务自己都带着application.yml,上百个配置文件的管理……接下来你会疯的。
(2)Config是什么?
SpringCloud Config为微服务架构中的微服务提供了集中化的外部配置支持,配置服务器为各个不同微服务应用的所有环境提供了一个中心化的外部配置。
SpringCloud Config分为服务端和客户端:
服务端:也被称为分布式配置中心,它是一个独立的微服务应用,用来连接配置服务器并为客户端提供获取配置信息,加密/解密信息等访问接口。
客户端:通过指定的配置中心来管理应用资源,以及与业务相关的配置内容,并在启动的时候从配置中心获取和加载配置信息,配置服务器默认采用git来存储配置信息,这样有助于对环境配置进行版本管理,并且可以用过git客户端工具来方便的管理和访问配置内容。

本项目地址:https://github.com/Simple-Coder/microservice-demo-study
二、SpringCloud Config服务端配置
(1)github新建仓库,名为:microservice-config
我这里已经建好地址:https://github.com/Simple-Coder/microservice-config
①根据ssh地址:git@github.com:Simple-Coder/microservice-config.git,在本地硬盘目录新建git仓库并clone

②在刚刚创建的本地仓库中新疆:application.yml,添加如下配置并通过git客户端推送到github
spring:
profiles:
active:
- dev
---
spring:
profiles: dev #开发环境
application: microservice-config-dev
---
spring:
profiles: test #测试环境
application:
name: microservice-config-test #保存为utf-8格式
application.yml

③新建Module模块:microservice-config3344(配置中心模块),Maven工程结构图如下:

④microservice-config模块:pom依赖、application.yml、启动类
<dependencies>
<!--config server-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-server</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-hystrix</artifactId>
</dependency>
</dependencies>
pom
server:
port: 3344
spring:
application:
name: microservice-config
cloud:
config:
server:
git:
uri: git@github.com:Simple-Coder/microservice-config.git #github上的仓库地址
application.yml
@SpringBootApplication
@EnableConfigServer
public class ConfigApplication {
public static void main(String[] args) {
SpringApplication.run(Application.class);
}
}
启动类
⑤本地hosts文件添加映射:C:\Windows\System32\drivers\etc\hosts

⑥启动microservice-config测试
(1)浏览器访问:http://config3344.com:3344/application-dev.yml,出现以下界面说明服务端配置成功!

(2)浏览器访问:http://config3344.com:3344/application-test.yml

(3)浏览器访问不存在的配置:http://config3344.com:3344/application-xx.yml

注:配置读取规则!

至此,成功实现了用SpringCloud Config通过github获取配置信息
三、SpringCloud Config客户端配置
(1)新建microservice-config-client3355模块,Maven模块图如下:

(2)microservice-config-client3355添加:pom、bootstrap.yml、application.yml
<dependencies>
<!--spring cloud config客户端-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-config</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-hystrix</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-context</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-eureka</artifactId>
</dependency>
</dependencies>
pom
spring:
cloud:
config:
name: microservice-config-client #需要从github上读取的资源名称,注意没有yml名称
profile: dev #本次访问的配置项
label: master
uri: http://config3344.com:3344 #本服务启动后先去找3344服务,通过SpringCloudConfig获取github的服务地址
bootstrap.yml
spring:
application:
name: microservice-config-client
application.yml
(3)本地hosts添加文件:C:\Windows\System32\drivers\etc\hosts

(4)依次启动:3个eureka集群、1个config server、1个config client
(5)config server自测:
http://config3344.com:3344/application-dev.yml和http://config3344.com:3344/application-test.yml

(6)根据config client的bootstrap.yml指定生效的profile如下:

(7)测试controller和控制台打印效果:
@RestController
public class TestController {
@Value("${spring.application.name}")
private String applicationname; @Value("${eureka.client.service-url.defaultZone}")
private String eurekaServsers; @Value("${server.port}")
private String port; @RequestMapping("/config")
public String getConfig()
{
System.out.println("applicationName:"+applicationname);
System.out.println("eurekaServers:"+eurekaServsers);
System.out.println("port:"+port);
return "applicationName:"+applicationname+"\t\n"+"eurekaServers:"+eurekaServsers+"\t\n"+"port:"+"\t"+port;
}
}
TestController

(8)浏览器访问:http://configclient.com:5001/config

(9)修改bootstrap.yml,再次查看控制台及访问路径:http://configclient.com:5002/config



至此,config 客户端的搭建完成!
四、SpringCloud Config配置实战
目前情况:
①Config服务端配置OK且测试通过,我们可以和config+github进行配置修改并获得内容
②此时:做一个eureka服务+一个provider访问的微服务,将两个微服务的配置统一由github实现统一配置分布式管理,完成多环境的变更
(1)Git配置文件本地配置
①本地git仓库新建:microservice-config-eureka.yml,添加如下配置:
spring:
profiles:
active:
- dev --- server:
port: 8001
spring:
profiles: dev
application:
name: microservice-config-eureka eureka:
instance:
hostname: eureka8001
client:
register-with-eureka: false
fetch-registry: false
service-url:
defaultZone: http://eureka8001:8001/eureka/ --- server:
port: 8001
spring:
profiles: test
application:
name: microservice-config-eureka eureka:
instance:
hostname: eureka8001
client:
register-with-eureka: false
fetch-registry: false
service-url:
defaultZone: http://eureka8001:8001/eureka/
microservice-config-eureka.yml
②本地git仓库新建:microservice-config-provider.yml,添加如下配置:
(2)Config版的eureka服务端
①启动config server自测:http://config3344.com:3344/microservice-config-eureka-test.yml

②microservice-config-eureka8001模块:bootstrap.yml添加如下配置

③启动类:application.java
@SpringBootApplication
@Slf4j
@EnableEurekaServer
public class Application {
public static void main(String[] args) {
try {
SpringApplication.run(ApplicationBoot.class, args);
} catch (Throwable t) {
log.error("启动失败", t);
throw t;
}
}
}
application.java
④测试,查看控制台

(2)Config版的provider微服务
①config server自测:http://config3344.com:3344/microservice-config-provider/test

②新建模块:microservice-config-provider9001,Maven工程结构图如下:

③该模块添加:pom依赖、bootstrap.yml、application.yml
<dependencies>
<!--spring cloud config客户端-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-config</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-hystrix</artifactId>
</dependency> <dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
</dependency> <dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<version>${spring-boot.version}</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>javax.el</groupId>
<artifactId>javax.el-api</artifactId>
<version>3.0.0</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
<scope>runtime</scope>
</dependency> <!--模块间引用-->
<dependency>
<groupId>com.microservice</groupId>
<artifactId>microservice-inf</artifactId>
<version>1.0.0</version>
</dependency>
<dependency>
<groupId>com.microservice</groupId>
<artifactId>microservice-service-impl</artifactId>
<version>1.0.0</version>
</dependency>
<dependency>
<groupId>com.microservice</groupId>
<artifactId>miscroservice-common</artifactId>
<version>1.0.0</version>
</dependency>
</dependencies>
pom
spring:
cloud:
config:
name: microservice-config-provider #需要从github上读取的资源名称,注意没有yml名称
profile: test #本次访问的配置项
label: master
uri: http://config3344.com:3344 #本服务启动后先去找3344服务,通过SpringCloudConfig获取github的服务地址
bootstrap.yml
spring:
application:
name: microservice-provider
application.yml
④依次启动:config-server、config-eureka、config-provider模块

⑤浏览器访问:http://localhost:9001/provider/all,出现以下结果:生效的profile为test

⑥将profile修改为dev,开发环境再次测试,访问:http://localhost:9001/provider/all

至此、分布式配置中心的客户端和服务器也已经测试完成!
五、总结
至此、SpringCloud的基本组件:Eureka、Ribbon、Feign、Hystrix、Zuul、Config已经了解了,接下来i就是一些进阶的,比如:
①SpringCloud Stream:数据流开发包
②SpringCloud Turbine:聚合服务器发送事件流数据的一个工具,用来监控集群下hystrix的metrics情况
③SpringCloud Task:提供云端计划任务管理、任务调度
④SpringCloud Sleuth:日志收集工具包实现了一种分布式追踪解决方案,封装了Dapper和log-based追踪以及Zipkin和HTrace操作。
⑤SpringCloud Security:基于spring security的安全工具包,为应用程序添加安全控制
以及其他方面的学习,例如:
①服务部署:Kubernetes、OpenStack
②全链路追踪:Zipkin,brave
③服务监控:zabbix
④SpringCloud CLI:基于Spring Boot CLI,可以以命令行的方式快速建立云组件
⑤全局控制:选举leader、全局锁、全局唯一id
⑥安全鉴权:Oauth2、openId connect
⑦自动化构建与部署:gitlab+jenkins+docker
SpringCloud全家桶学习之分布式配置中心----Config(七)的更多相关文章
- SpringCloud全家桶学习之Feign负载均衡----Feign(四)
一.Feign概述 (1)Feign是什么? 官网地址:https://projects.spring.io/spring-cloud/spring-cloud.html#spring-cloud-f ...
- SpringCloud学习系列之五-----配置中心(Config)和消息总线(Bus)完美使用版
前言 在上篇中介绍了SpringCloud Config的使用,本篇则介绍基于SpringCloud(基于SpringBoot2.x,.SpringCloud Finchley版)中的分布式配置中心( ...
- Spring-cloud微服务实战【九】:分布式配置中心config
回忆一下,在前面的文章中,我们使用了spring cloud eureka/ribbon/feign/hystrix/zuul搭建了一个完整的微服务系统,不管是队内还是对外都已经比较完善了,那我们 ...
- SpringCloud学习系列之四-----配置中心(Config)使用详解
前言 本篇主要介绍的是SpringCloud中的分布式配置中心(SpringCloud Config)的相关使用教程. SpringCloud Config Config 介绍 Spring Clou ...
- SpringCloud教程 | 第六篇: 分布式配置中心(Spring Cloud Config)
一.简介 在分布式系统中,由于服务数量巨多,为了方便服务配置文件统一管理,实时更新,所以需要分布式配置中心组件.在Spring Cloud中,有分布式配置中心组件spring cloud config ...
- 史上最简单的SpringCloud教程 | 第六篇: 分布式配置中心(Spring Cloud Config)
一.简介 在分布式系统中,由于服务数量巨多,为了方便服务配置文件统一管理,实时更新,所以需要分布式配置中心组件. 在Spring Cloud中,有分布式配置中心组件spring cloud confi ...
- SpringCloud教程 | 第六篇: 分布式配置中心(Spring Cloud Config)(Finchley版本)
在上一篇文章讲述zuul的时候,已经提到过,使用配置服务来保存各个服务的配置文件.它就是Spring Cloud Config. 一.简介 在分布式系统中,由于服务数量巨多,为了方便服务配置文件统一管 ...
- 【SpringCloud】第六篇: 分布式配置中心(Spring Cloud Config)
前言: 必需学会SpringBoot基础知识 简介: spring cloud 为开发人员提供了快速构建分布式系统的一些工具,包括配置管理.服务发现.断路器.路由.微代理.事件总线.全局锁.决策竞选. ...
- SpringCloud分布式配置中心Config
统一管理所有配置. 1.微服务下的分布式配置中心 简介:讲解什么是配置中心及使用前后的好处 什么是配置中心: 一句话:统一管理配置, 快速切换各个环境的配置 相关产品: 百度的disconf 地址:h ...
随机推荐
- 【Redis运行状态下切换RDB备份至AOF备份】
"redis持久化方式有哪些?又有何区别? rdb:基于快照的持久化,速度更快,一般用作备份,主从复制也是依赖于rdb持久化功能. aof:以追加的方式记录redis操作日志的文件,可最大程 ...
- Android 验证APK签名对比
最近OTT制定产品,其中有一条需求是只能安装自己公司签名的APK,所以在网上找了相关资料,最后总结功能实现如下: 1.签名错误码frameworks/base/core/java/android/co ...
- Jarvis OJ - [XMAN]level1 - Writeup
Jarvis OJ - [XMAN]level1 - Writeup M4x原创,转载请表明出处http://www.cnblogs.com/WangAoBo/p/7594173.html 题目: 分 ...
- 一、centos7更改网卡名称eth0
异步赠书:10月Python畅销书升级 [线路图]人工智能到底学什么?! 程序员10月书讯 每周荐书(京东篇):618取胜之道.质量保障.技术解密) Centos7更改网卡名称Eth0 标签: Cen ...
- python之路之css拾遗
做一个鼠标碰到就会自动加边框的效果 下边的代码,主要是使自动加边框的时候,加边框的部分不会跳动 实现一张图片的点击之后出现信息
- AcWing 906. 区间分组
//1.将所有区间按左端点从小到大排序 //2.从前往后处理每个区间,判断能否将其放到某个现有的组中 //判断某一组的最后一个区间的右端点是否小于该区间的左端点 //如果大于或等于,就开新组,如果小于 ...
- python 中if和elif的区别
如果程序中判断事件很多,全部用if的话,会遍历整个程序,用elif 程序运行时,只要if或后续某一个elif之一满足逻辑值为True,则程序执行完对应输出语句后自动结束该轮if-elif(即不会再去冗 ...
- 题解 P3951 小凯的疑惑
P3951 小凯的疑惑 数论极菜的小萌新我刚看这题时看不懂exgcd做法的题解,后来在网上找到了一篇博客,感觉代码和推导都更加清新易懂,于是在它的基础上写了题解qwq 分析 两数互质,且有无限个,想到 ...
- 【Thinkphp】记录一次分页的实现
thinkphp分页非常简单 1,控制器渲染数据: $studentList = StudentDb::paginate(5); $this->view->assign('list',$s ...
- 【网易官方】极客战记(codecombat)攻略-地牢-Kithmaze 二度历险
关卡连接: https://codecombat.163.com/play/level/the-second-kithmaze 很多人试过,但只有少数人能穿过此迷宫. 简介: 记住,你只需 一个 wh ...