系列文章(更新ing):

「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现

「 从0到1学习微服务SpringCloud 」03 Eureka的自我保护机制

「 从0到1学习微服务SpringCloud 」04服务消费者Ribbon+RestTemplate

「 从0到1学习微服务SpringCloud 」05消费者Fegin

是什么?

如名字一样,就是用来统一管理配置文件的组件

为什么需要它?

1.不方便维护

多人同时对配置文件进行修改,冲突不断,很难维护

2.配置内容安全和权限

主要是针对线上的配置来说,一般不对开发公开,只有运维有权限所以需要将配置文件隔离,不放到项目代码里

3.更新配置项目需要重启

每次更新配置文件都需要重启项目,很耗时。使用了配置中心后,即可实现配置实时更新

原理

1.配置文件存储在远端git(比如github,gitee等仓库),config-server从远端git拉取配置文件,并保存到本地git。

2.本地git和config-server的交互是双向的,因为当远端git无法访问时,会从本地git获取配置文件

3.config-client(即各个微服务),从config-server拉取配置文件

实战

RabbitMQ

项目需要配合使用RabbitMQ实现,需要先安装RabbitMQ。

公众号提供64位win安装包(公众号后台回复【rbmq】获取)

安装成功后,可打开RabbitMQ管理界面http://localhost:15672

默认账号密码:guest/guest

git仓库创建配置文件

1.master分支新建client.yml

  1. server:
  2. port: 8861
  3. spring:
  4. application:
  5. name: client
  6. label: master

2.master分支新建client-dev.yml

  1. server:
  2. port: 8861
  3. spring:
  4. application:
  5. name: client
  6. profile: dev
config-server

1.新建一个配置中心服务端项目,同时勾选Config Server和Eureka Discovery,作为配置中心服务端和Eureka客户端

2.启动类加注解@EnableEurekaClient@EnableConfigServer

  1. @SpringBootApplication
  2. @EnableEurekaClient
  3. @EnableConfigServer
  4. public class ConfigApplication {
  5. public static void main(String[] args) {
  6. SpringApplication.run(ConfigApplication.class, args);
  7. }
  8. }

3.编写configServer配置

  1. server:
  2. port: 8961
  3. eureka:
  4. client:
  5. service-url:
  6. defaultZone: http://localhost:8761/eureka/
  7. spring:
  8. application:
  9. name: config
  10. cloud:
  11. config:
  12. server:
  13. git:
  14. uri: 配置中心git地址
  15. username: 账号
  16. password: 密码
  17. #本地git保存地址
  18. basedir: D:\Work\HqProject\config\basedir
  19. #向外暴露接口
  20. #主要是为了暴露/actuator/bus-refresh,刷新配置信息
  21. management:
  22. endpoints:
  23. web:
  24. exposure:
  25. include: "*"

4.添加Spring cloud bus的maven(Spring cloud bus作为消息总线,mq作为消息中间件,传递信息)

  1. <dependency>
  2. <groupId>org.springframework.cloud</groupId>
  3. <artifactId>spring-cloud-starter-bus-amqp</artifactId>
  4. </dependency>

5.启动Config 项目,注册到Eureka,启动成功后会自动添加RabbitMQ队列

6.访问地址http://localhost:8961/client-dev.yml可以访问到配置文件

config-client

继续使用上节的项目eureka-client

1.添加Config-client和Spring cloud bus的maven

  1. <dependency>
  2. <groupId>org.springframework.cloud</groupId>
  3. <artifactId>spring-cloud-config-client</artifactId>
  4. </dependency>
  5. <dependency>
  6. <groupId>org.springframework.cloud</groupId>
  7. <artifactId>spring-cloud-starter-bus-amqp</artifactId>
  8. </dependency>

2.修改配置文件名字,改为bootstrap.yml,这个配置文件默认优先级最高,如果不这样做,项目会默认Config-Server的端口号为localhost:8888(bootstrap意为:引导启动 只是刚好和前端框架bootstrap名字相同,它们没有关系)

3.修改配置

  1. server:
  2. port: 8861
  3. eureka:
  4. client:
  5. service-url:
  6. defaultZone: http://localhost:8761/eureka/
  7. spring:
  8. application:
  9. name: client
  10. cloud:
  11. #Config相关配置
  12. config:
  13. discovery:
  14. enabled: true
  15. #Config-server的服务名
  16. service-id: CONFIG
  17. #环境
  18. profile: dev
  19. #分支
  20. label: master

这里的配置关乎拉取的规则,如下

  1. 1.{name}.yml
  2. 2.{name}-{profile}.yml
  3. 3.{label}/{name}-{profile}.yml
  4. name:服务名
  5. profile:环境
  6. label:分支

1.若没有声明profile(环境),采用第1种规则,默认为master分支

2.若没有声明label(分支)时,采用第2种规则,默认为master分支

ps:当声明了profile(环境)时,会同时获取{name}.yml和{name}-{profile}.yml文件,然后合并。所以在{name}.yml文件中可写一些通用的配置

4.新建两个controller,测试从获取到的配置

  1. @RestController
  2. //这个注解为 刷新区域
  3. //有这个注解,配置才能刷新
  4. @RefreshScope
  5. public class EnvController {
  6. @Value("${env}")
  7. private String env;
  8. @GetMapping("env")
  9. public String getEnv(){
  10. return env;
  11. }
  12. }
  13. @RestController
  14. @RefreshScope
  15. public class FenzhiController {
  16. @Value("${fenzhi}")
  17. private String fenzhi;
  18. @GetMapping("fenzhi")
  19. public String getFenzhi(){
  20. return fenzhi;
  21. }
  22. }

5.启动项目,注册到Eureka,启动成功后,控制台会显示成功拉取配置,并自动添加RabbitMQ队列

6.分别访问http://localhost:8861/envhttp://localhost:8861/fenzhi可获取到相应配置

下面的效果就表名,声明了profile(环境)时,会同时获取{name}.yml和{name}-{profile}.yml文件

手动刷新配置

1.修改git仓库中client-dev.yml的env改为test

2.使用Postman发送Post请求http://localhost:8961/actuator/bus-refresh(ConfigServer的服务),告诉ConfigServer,配置更新了,拉取最新配置到ConfigServer,并通过bus发送给各个ConfigClient,让它们拉取最新配置

3.访问http://localhost:8861/env,env已修改为了test,表明已获取最新配置

自动刷新配置

1.安装内网穿透软件(使外网能访问本机),我这里使用的ngrok(官网:https://ngrok.com) 官方了提供免费的,可用于测试

注册登录后,会有操作说明,如下(我想,你应该能看懂)

2.我这直接跳到第4步,开启ngrok,映射到本地8961端口(ConfigServer的端口)

到ngrok所在目录,打开console控制台,输入ngrok http 8961

3.访问ngrok所给的域名,已成功映射(有时可能会有网络问题,多刷新几次)

4.ConfigServer应用添加maven依赖,重启应用

  1. <dependency>
  2. <groupId>org.springframework.cloud</groupId>
  3. <artifactId>spring-cloud-config-monitor</artifactId>
  4. </dependency>

5.配置 WebHooks

5.1 Gitlab WebHooks 配置方法:

5.2 Github  WebHooks 配置方法:

5.3 Gitee(码云) WebHooks 配置方法:

可点击测试按钮,测试一下钩子是否能访问。(如果失败,可更换内网穿透软件,比如natapp等)

配置成功后,会在每次 push 代码后,都会给远程 HTTP URL 发送一个 POST 请求。

上面的URL就需要使用到内网穿透获取到的域名了,url为内网穿透域名/monitor

6.修改git仓库上client-dev.yml的env改为test123,通过ConfigClient获取env已更新为test123,已实现自动刷新

好叻,搞定,下节继续!

如果觉得不错,分享给你的朋友!

THANDKS

  • End -

一个立志成大腿而每天努力奋斗的年轻人

伴学习伴成长,成长之路你并不孤单!

「 从0到1学习微服务SpringCloud 」06 统一配置中心Spring Cloud Config的更多相关文章

  1. 「 从0到1学习微服务SpringCloud 」10 服务网关Zuul

    系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」06 统一配置中心Spring Cloud Config 「 从0到1学习微服务SpringCloud 」07 RabbitM ...

  2. 「 从0到1学习微服务SpringCloud 」09 补充篇-maven父子模块项目

    系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」06 统一配置中心Spring Cloud Config 「 从0到1学习微服务SpringCloud 」07 RabbitM ...

  3. 「 从0到1学习微服务SpringCloud 」08 构建消息驱动微服务的框架 Spring Cloud Stream

    系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现 「 从0到1学习微服务S ...

  4. 「 从0到1学习微服务SpringCloud 」07 RabbitMq的基本使用

    系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现 「 从0到1学习微服务S ...

  5. 「 从0到1学习微服务SpringCloud 」05服务消费者Fegin

    系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现 「 从0到1学习微服务S ...

  6. 「 从0到1学习微服务SpringCloud 」04服务消费者Ribbon+RestTemplate

    系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现 「 从0到1学习微服务S ...

  7. 「 从0到1学习微服务SpringCloud 」03 Eureka的自我保护机制

    系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现 Eureka的高可用需要 ...

  8. 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现

    系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! Spring Cloud Eureka 基于Netflix Eureka做了二次封装(Spring Clo ...

  9. 「 从0到1学习微服务SpringCloud 」01 一起来学呀!

    有想学微服务的小伙伴没?一起来从0开始学习微服务SpringCloud,我会把学习成果总结下来,供大家参考学习,有兴趣可以一起来学!如有错误,望指正! Spring .SpringBoot.Sprin ...

随机推荐

  1. JUnit 单元测试断言推荐 AssertJ

    文章转自:http://sgq0085.iteye.com/blog/2030609 前言 由于JUnit的Assert是公认的烂API,所以不推荐使用,目前推荐使用的是AssertJ. Assert ...

  2. SDOI2019热闹又尴尬的聚会

    P5361 [SDOI2019]热闹又尴尬的聚会 出题人用脚造数据系列 只要将\(p\)最大的只求出来,\(q\)直接随便rand就能过 真的是 我们说说怎么求最大的\(p\),这个玩意具有很明显的单 ...

  3. CodeForces - 375D Tree and Queries (莫队+dfs序+树状数组)

    You have a rooted tree consisting of n vertices. Each vertex of the tree has some color. We will ass ...

  4. DataBinding + Kotlin +Viewpager

    1.创建viewmodel,其中BindAdapter的方法需要是静态方法,因此需要加@JvmStatic,"app:img"相当于一个自定义属性,后面xml中会用到,当app:i ...

  5. Vsual Studio 2010可用的sqlite驱动程序(实体数据模型使用)

    背景 昨天一个旧的项目(.net framework 4 + EF4 +sqlite + edmx db first),数据库结构有变更,要更新实体edmx模型 先是到官网下载最新的驱动,结果不能更新 ...

  6. Android7_安卓的知识体系梳理

    最近梳理了一下安卓的知识体系,先构建一个整体性的认知,也作为以后的学习路线的依据. [一.从原理角度出发]1.Activity生命周期和启动模式2.View的事件体系与工作原理3.四大组件的工作过程4 ...

  7. QP移植

    以STM32平台为例,该单片机的ARM Cortex-M系列内核正是被QP长期支持,所以QP在ARM Cortex-M系列内核上已经有长时间的应用验证. 在配套书籍PSICC2中的例程为QP最原始的版 ...

  8. CodeForces 796D

    不能一个一个bfs,要一起bfs #include<iostream> #include<vector> #include<cstdio> #include< ...

  9. ELK学习实验006:Nginx的日志分析系统之filebeat配置

    一 Filebeat工作原理 Filebeat由两个主要组件组成: prospector和 harvester 1.1 harvester 负责读取单个文件的内容 如果文件在读取时被制除或重命名, F ...

  10. 工具系列 | Docker基本概念小结

    ▍什么是Docker? Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的 Linux或Windows 机器上,也可以实现虚拟化.容 ...