一、概述

(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(七)的更多相关文章

  1. SpringCloud全家桶学习之Feign负载均衡----Feign(四)

    一.Feign概述 (1)Feign是什么? 官网地址:https://projects.spring.io/spring-cloud/spring-cloud.html#spring-cloud-f ...

  2. SpringCloud学习系列之五-----配置中心(Config)和消息总线(Bus)完美使用版

    前言 在上篇中介绍了SpringCloud Config的使用,本篇则介绍基于SpringCloud(基于SpringBoot2.x,.SpringCloud Finchley版)中的分布式配置中心( ...

  3. Spring-cloud微服务实战【九】:分布式配置中心config

      回忆一下,在前面的文章中,我们使用了spring cloud eureka/ribbon/feign/hystrix/zuul搭建了一个完整的微服务系统,不管是队内还是对外都已经比较完善了,那我们 ...

  4. SpringCloud学习系列之四-----配置中心(Config)使用详解

    前言 本篇主要介绍的是SpringCloud中的分布式配置中心(SpringCloud Config)的相关使用教程. SpringCloud Config Config 介绍 Spring Clou ...

  5. SpringCloud教程 | 第六篇: 分布式配置中心(Spring Cloud Config)

    一.简介 在分布式系统中,由于服务数量巨多,为了方便服务配置文件统一管理,实时更新,所以需要分布式配置中心组件.在Spring Cloud中,有分布式配置中心组件spring cloud config ...

  6. 史上最简单的SpringCloud教程 | 第六篇: 分布式配置中心(Spring Cloud Config)

    一.简介 在分布式系统中,由于服务数量巨多,为了方便服务配置文件统一管理,实时更新,所以需要分布式配置中心组件. 在Spring Cloud中,有分布式配置中心组件spring cloud confi ...

  7. SpringCloud教程 | 第六篇: 分布式配置中心(Spring Cloud Config)(Finchley版本)

    在上一篇文章讲述zuul的时候,已经提到过,使用配置服务来保存各个服务的配置文件.它就是Spring Cloud Config. 一.简介 在分布式系统中,由于服务数量巨多,为了方便服务配置文件统一管 ...

  8. 【SpringCloud】第六篇: 分布式配置中心(Spring Cloud Config)

    前言: 必需学会SpringBoot基础知识 简介: spring cloud 为开发人员提供了快速构建分布式系统的一些工具,包括配置管理.服务发现.断路器.路由.微代理.事件总线.全局锁.决策竞选. ...

  9. SpringCloud分布式配置中心Config

    统一管理所有配置. 1.微服务下的分布式配置中心 简介:讲解什么是配置中心及使用前后的好处 什么是配置中心: 一句话:统一管理配置, 快速切换各个环境的配置 相关产品: 百度的disconf 地址:h ...

随机推荐

  1. Oracle 11g安装 —— Oracle Database 11g Release2 for Windows(x64)

    文章来自:https://blog.csdn.net/IT_xiao_guang_guang/article/details/104422421 下面是我的Oracle 11g安装过程,希望可以帮到正 ...

  2. Vue中自动获取input焦点

    <input v-focus type="text" name="search" ref="input" autofocus v-mo ...

  3. tp5.1 Auth类实现权限管理

    了解来这么久权限控制权限的知识,却不知道如何写代码,网上的代码多数并没有多少完整的源码能提供参考.偶然看到官网的例子,现在终于也把源码的实现也弄得明白了一点. tp5框架的Auth类可以实现页面的访问 ...

  4. Redis Distributed lock

    using StackExchange.Redis; using System; using System.Collections.Generic; using System.Linq; using ...

  5. ASP.NET MVC扩充数据模型-定义数据模型的Metadata

    ASP.NET MVC扩充数据模型-定义数据模型的Metadata Posted on 2018-07-12 by Wang Kepai     Rate this post 无论你是使用LINQ t ...

  6. java程序启动参数

    例如 启动进程如下 /home/work/noah/ccs/jc-controller/jdk1.7.0_55/bin/java -Xmx4096m -Xms4096m -Xmn1024m -XX:+ ...

  7. (c#)最小绝对差

    题目 解

  8. hdu 1532 Drainage Ditches(网络流)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1532 题目大意是:农夫约翰要把多个小池塘的水通过池塘间连接的水渠排出去,从池塘1到池塘M最多可以排多少 ...

  9. docker-api的使用(java)

    通过docker-api来执行docker相关的操作.   配置 可以在docker启动文件docker.service中加入如下 vi /lib/systemd/system/docker.serv ...

  10. JS高级---为内置对象添加原型方法

    为内置对象添加原型方法 我们能否为系统的对象的原型中添加方法, 相当于在改变源码   我希望字符串中有一个倒序字符串的方法 //我希望字符串中有一个倒序字符串的方法 String.prototype. ...