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 ...
随机推荐
- [CF]Round513
A Phone Numbers 题意:定义"电话号码"为开头为'8',长度为11的字符串.给定一些字符,每个字符只能用一次,求可以拼出多少个电话号码(可以重复). 直接min(st ...
- Oracle 11g安装 —— Oracle Database 11g Release2 for Windows(x64)
文章来自:https://blog.csdn.net/IT_xiao_guang_guang/article/details/104422421 下面是我的Oracle 11g安装过程,希望可以帮到正 ...
- c数据结构 绪论
四种逻辑结构:1:集合结构 结构中的数据元素除了同属于同一个集合的关系外,无任何其他关系2:线性结构 结构中的数据元素之间存在着一对一的线性关系3:树形结构 结构中的数据元素之间存在着一对多的层次关系 ...
- ASP.NET + MVC5 入门完整教程四---MVC 中使用扩展方法
https://blog.csdn.net/qq_21419015/article/details/80433640 1.示例项目准备1)项目创建新建一个项目,命名为LanguageFeatures ...
- php设计模式之面向接口开发实例代码
<?php header("Content-type:text/html;charset=utf-8"); /** * 共同接口 */ interface db { func ...
- Linux(Ubuntu)服务器是否安装ssh,使用xshell远程连接
1.查看 ssh 是否启动,如果有 sshd 说明已经启动 sudo ps -e | grep ssh 2.启动 ssh 服务 sudo service ssh start 3.如果第二步没有成功启动 ...
- HTTP状态码详解(下)
接上文 HTTP状态码详解(上). 详细的描述状态码之(3**) 300:被请求的资源有一系列可供选择的回馈信息,每个都有自己特定的地址和浏览器驱动的商议信息.用户或浏览器能够自行选择一个首选的地址进 ...
- Html学习笔记(二)
Html头部 HTML <link>元素 <link> 标签定义了文档与外部资源之间的关系. <link> 标签通常用于链接到样式表: <head> & ...
- 利用Xshell5从本机上向Linux(虚拟机中)上传文件
Xmanager Enterprise 5云盘分享: http://pan.baidu.com/s/1jIkiQNW 1. 用ifconfig命令查看Linux的IP地址 2. 由于没有IP,所以我 ...
- buuctf 基础破解
首先下载压缩包 解压之后发现是另一个压缩包 另一个压缩包上写着基础破解 然后用暴力破解的方法破解 然后搜了一下 暴力破解一般的长度是多少 然后搜到的结果是 长度为8的时候电脑都要破解好几年 所以我猜测 ...