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 ...
随机推荐
- SpringMVC 配置.html拦截时,返回JSON数据时出现406错误解决方案
[说明]在SpringMVC框架的使用中常常会使用@ResponseBody注解,修饰"处理器"(Controller的方法),这样在处理器在返回完毕后,就不走逻辑视图,而是将返回 ...
- k线生成模块
1.支持任意周期K线. 2.支持K线偏移. 3.支持指数.主力. 4.支持文华商品指数. 默认支持的是:5秒.1分钟.3分钟.5分钟.日线. 时间:2010年到现在. 数据如下: 5秒线,大宗商品指数 ...
- C#画图超出屏幕的部分无法显示的解决方法
C#画图超出屏幕的部分无法显示,通过AutoScrollMinSize属性及相关方法解决问题. 可以实现 到 的转变. 代码如下: using System.Drawing; using System ...
- windows下划分逻辑分区
运行命令窗口后,我们输入命令"diskpart"回车! 然后我们在DISKPART>后面输入select disk 0 选择我们的硬盘,然后回车!当然如果你电脑上有好几块硬盘 ...
- C# 选取本月周六日方法
用于工作: 1.取本月第一天就是1号 2.取下月第一天再减去一天 就是本月最后一天 3.从月头遍历至月末,判断周几 代码如下: #region 提取本月周六日 DateTime start = new ...
- Iris配置
package main import ( "github.com/kataras/iris" "os" "encoding/json" & ...
- ABB工业机器人(条件执行数字信号判断,画方or画圆)
一.前戏 条件:从安全点,到工具区域夹取工具(笔),到工作区域,判断数字信号 Di1 =1 ,Ture :画方,False:画圆,回到工具区域放下工具(笔),回到安全点 二. 准备工作 校准tcp工具 ...
- dbGet (二)
dbGet是由它基本的语法加上各种object的attribute的组合构成的.大家在熟悉基本语法之后,就应该去学习各个object的attribute了.说实话,这很难,因为attribute很多, ...
- PMP概略学习下--主体内容
4 知识主体 4.1 主要知识简介 PMP所有的知识围绕五大过程组和十大知识领域展开.五大过程组包括启动.规划.执行.监控.结尾.启动的内容主要是定义项目或阶段.获得授权以及正式开始:规划的内容主要 ...
- js无缝滚动跑马灯
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...