原文:http://www.jianshu.com/p/b17d65934b58%20

前言

在微服务架构中,由于服务数量众多,如果使用传统的配置文件管理方式,配置文件分散在各个项目中,不易于集中管理和维护。在 spring cloud 中使用 config-server 集中管理配置文件,可以使用 gitsvn本地资源目录 来管理配置文件,在集成了 spring cloud bus 之后还可以通过一条 post 请求,让所有连接到消息总线的服务,重新从config-server 拉取配置文件,非常方便。

创建config-server

新建一个maven工程,修改pom.xml引入 spring cloud 依赖:

<parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>1.4.2.RELEASE</version>
</parent><dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-config-server</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-eureka</artifactId></dependency>
</dependencies><dependencyManagement><dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-dependencies</artifactId><version>Camden.SR2</version><type>pom</type><scope>import</scope></dependency></dependencies>
</dependencyManagement>

在 resources 目录中创建 application.yml 配置文件,在配置文件内容:

spring:application:name: @project.artifactId@cloud:config:server:git:uri: https://git.oschina.net/yuelenghan/soa-demo.gitsearchPaths: spring-cloud-2.0/config-repousername: usernamepassword: passwordserver:port: 8888eureka:client:serviceUrl:defaultZone: http://localhost:8000/eureka/

这里使用 git 作为配置文件管理,searchPaths 指定配置文件所在的目录,username 和password 分别git仓库的用户名和密码。

这里把 config-server-demo 也注册到 eureka,这样在 eureka 注册的服务,就可以通过指定 config-server-demo 的 serviceId ,从 config-server-demo 拉取配置文件,这样的话在 config-server 改变url时,就不需要修改代码了,而且在多实例情况下也可以负载均衡。

在 java 目录中创建一个包 demo ,在包中创建启动入口ConfigServerApplication.java

@EnableDiscoveryClient
@SpringBootApplication
@EnableConfigServer
public class ConfigServerApplication {public static void main(String[] args) {SpringApplication.run(ConfigServerApplication.class, args);}}

这里使用了 @EnableConfigServer 注解,设置此工程为配置中心。

在服务注册中心已经运行的情况下,运行 ConfigServerApplication.java 中的 main 方法,启动配置中心。
访问服务注册中心页面 http://localhost:8000, 可以看到已经成功注册了 CONFIG-SERVER-DEMO 配置中心。

修改配置文件加载方式

至此配置中心已经创建好了,我们把之前的项目 service-gateway-demo 和 add-service-demo 拿过来改造一下,让这两个项目从配置中心加载配置文件。
给 service-gateway-demo 和 add-service-demo 增加maven依赖:

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-config</artifactId>
</dependency>

删除之前的配置文件 application.yml 和 application-docker.yml,新建配置文件bootstrap.yml,文件内容:

spring:application:name: @project.artifactId@profiles:active: @activatedProperties@cloud:config:profile: devlabel: masterdiscovery:enabled: trueserviceId: CONFIG-SERVER-DEMOfailFast: trueretry:initialInterval: 10000multiplier: 2maxInterval: 60000maxAttempts: 10eureka:client:serviceUrl:defaultZone: http://localhost:8000/eureka/

bootstrap.yml 在加载顺序上先于 application.yml ,常用于配置一些初始化的配置项。

这里主要看下 spring.cloud.config 节点下的配置, profile 和 label 这两个配置一起决定加载哪个配置文件。label 表示配置文件所在分支,配置文件的名称为{ApplicationName}-{profile}.yml 或 {ApplicationName}-{profile}.properties
根据配置文件中的配置信息,add-service-demo 加载的配置文件为 add-service-demo-dev.yml,文件在 git 仓库的 master 分支下。service-gateway-demo 加载的配置文件为service-gateway-demo-dev.yml,文件同样在 git 仓库的 master 分支下,文件路径都为 spring-cloud-2.0/config-repo
spring.cloud.discovery.enabled 和 spring.cloud.discovery.serviceId,这两个配置项配置了从服务注册中心获取 config-server-demo 的地址,而不使用传统url的方式。
spring.cloud.config.failFast 和 spring.cloud.config.retry 联合配置失败重试策略。

在 git 仓库的 master 分支下的 spring-cloud-2.0/config-repo 目录中新增两个配置文件:add-service-demo-dev.yml 和 service-gateway-demo-dev.yml
add-service-demo-dev.yml:

server:port: 8100

这里只需要配置端口即可,注册中心的地址已经在 bootstrap.yml 中进行了配置。

service-gateway-demo-dev.yml:

 server:port: 80zuul:routes:add-service-demo:path: /add-service/**serviceId: add-service-demo

启动 add-service-demo 和 service-gateway-demo,注意观察控制台,可以看到:
Fetching config from server at: http://config-server的IP:8888/,说明配置文件从 config-server 中拉取。

集成spring cloud bus功能

给 config-server-demoservice-gateway-demoadd-service-demo 这3个工程分别添加 spring cloud bus 的maven依赖:

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>

修改 config-server-demo 的配置文件 application.yml,在 spring 节点下增加 rabbitmq的配置信息:

rabbitmq:host: rabbitmq地址port: 端口username: guestpassword: guest

在git仓库中修改 service-gateway-demo 和 add-service-demo 的配置文件,增加rabbitmq 的配置信息:

spring:rabbitmq:host: rabbitmq地址port: 端口username: guestpassword: guest

在 add-service-demo-dev.yml 中额外增加一条用于测试的配置信息:my.info.str: test1111,修改 AddController.java,输出这条配置信息:

@RestController
@RefreshScope
public class AddController {@Value("${my.info.str}")private String infoStr;@RequestMapping(value = "/add", method = RequestMethod.GET)public Map<String, Object> add(Integer a, Integer b) {System.out.println("端口为8100的实例被调用");System.out.println("infoStr : " + infoStr);Map<String, Object> returnMap = new HashMap<>();returnMap.put("code", 200);returnMap.put("msg", "操作成功");returnMap.put("result", a + b);return returnMap;}}

这里增加了一个 @RefreshScope 注解,表明 AddController 这个 Bean 中的配置可动态刷新。

先启动 config-server-demo,配置服务启动完毕后,启动 add-service-demo 和 service-gateway-demo
打开 rabbitmq 的web管理页面,可以看到有3个 connection 连接到了 rabbitmq
访问 http://localhost/add-service/add?a=1&b=2 查看 add-service-demo 的控制台打印出的 infoStr 信息,infoStr : test1111
修改 git 仓库中的 add-service-demo-dev.yml 文件里的 my.info.str 配置,提交后发送bus 刷新的指令,向使用 spring cloud bus 的服务发送一条post请求,随便哪一个都行,这里以 config-server-demo 为例: curl -X POST http://localhost:8888/bus/refresh,发送这条 post 信息之后,查看控制台的输出日志,会发现 add-service-demo 和 service-gateway-demo 会重新加载 git 仓库中的配置文件。
再次访问 http://localhost/add-service/add?a=1&b=2,控制台输出了修改之后的 infoStr信息。

使用docker-maven-plugin打包并生成docker镜像

这里的内容和前几篇文章基本相同,都是把配置文件复制一份,修改为 docker 环境下的配置,在 pom.xml 中增加 docker 环境的profile。这里不再赘述,直接附上源码:
demo源码 spring-cloud-2.0目录

最后

目前为止,已经有了服务注册中心、配置中心、服务网关、消息总线、服务提供者和消费者,并且在网关层做了前端跨域处理。在开发层面,使用这些内容已经可以进行简单微服务的开发了。
但是在服务运维方面,尤其在服务数量不断增多的情况下,日志分散在各个工程下,如何进行日志聚合,方便的查看日志信息。服务之间互相调用出错时如何快速排查,如何熔断降级,使错误不至于影响整个服务网络。这些内容涉及到日志聚合、服务追踪、熔断器等,将在后续的文章中再做介绍。
下一篇介绍如何在 docker 环境下部署 zookeeper 和 kafka ,以及使用 log4j2 的 kafka appender 把微服务中的日志聚合输出到 kafka 中,为后边搭建 ELK 日志统计分析环境做准备。

基于docker部署的微服务架构(四): 配置中心相关推荐

  1. 基于docker部署的微服务架构(九): 分布式服务追踪 Spring Cloud Sleuth

    为什么80%的码农都做不了架构师?>>>    前言 微服务架构中完成一项功能经常会在多个服务之间远程调用(RPC),形成调用链.每个服务节点可能在不同的机器上甚至是不同的集群上,需 ...

  2. spring cloud+dotnet core搭建微服务架构:配置中心续(五)

    前言 上一章最后讲了,更新配置以后需要重启客户端才能生效,这在实际的场景中是不可取的.由于目前Steeltoe配置的重载只能由客户端发起,没有实现处理程序侦听服务器更改事件,所以还没办法实现彻底实现这 ...

  3. 微服务架构中配置中心的选择

    点击上方蓝色"方志朋",选择"设为星标" 回复"666"获取独家整理的学习资料! 来源:r6d.cn/XsTR 目前公司内部微服务架构基础设 ...

  4. spring cloud+dotnet core搭建微服务架构:配置中心(四)

    前言 我们项目中有很多需要配置的地方,最常见的就是各种服务URL地址,这些地址针对不同的运行环境还不一样,不管和打包还是部署都麻烦,需要非常的小心.一般配置都是存储到配置文件里面,不管多小的配置变动, ...

  5. 最新版Spring Cloud Alibaba微服务架构-Config配置中心篇

    文章目录 前言 一.Config引入背景 1.文件相对分散 2.无法区分环境 3.无法实时更新 4.安全无法保证 二.Config引入配置 1.配置文件格式 1.1 命名空间(Namespace) 1 ...

  6. dubbo k8s 服务发现_工商银行基于 Dubbo 构建金融微服务架构的实践-服务发现篇

    作者 | 张远征来源|阿里巴巴云原生公众号 导读:Dubbo 作为分布式微服务框架,众多公司在实践中基于 Dubbo 进行分布式系统架构.重启开源后,我们不仅看到 Dubbo 3.0 最新的 Road ...

  7. 基于Spring Cloud的微服务架构

    关于基于Spring Cloud的微服务应用架构,网上已经有很多文章了,但我还是觉得把自己的架构过程和经验写下来,对自己来说算是知识和技术的梳理,对于误打误撞进来看到这篇文章的读者来说,或许也能起到一 ...

  8. Docker学习篇——使用Docker部署账单微服务项目

    Docker概念 Docker 是一个开源的应用容器引擎 诞生于 2013 年初,基于 Go 语言实现, dotCloud 公司出品(后改名为Docker Inc) Docker 可以让开发者打包他们 ...

  9. 即插即用!开源项目【云框架】发布“基于Spring cloud的微服务架构”

    开发者面对新技术无非两个场景,一是不懂技术想要学习,二是懂技术想要使用. 前者需要考虑如何快速掌握技术原理并能把技术用起来,而后者需要琢磨如何花费最小代价将技术应用于生产环境. 换句话说,想要获得新技 ...

最新文章

  1. 疫情之下,武汉女生在家中答辩,获得国外博士学位!
  2. JS大宗师Douglas新书即将开印,就差一个书名了
  3. 用神经网络做分子模型:乙烯和乙炔的实验数据
  4. Android官方开发文档Training系列课程中文版:OpenGL绘图之图形绘制
  5. python围棋程序在屏幕上找棋盘_用C语言编程 在屏幕上显示围棋棋盘
  6. Office 2007打开提示:The setup controller ..
  7. Java常用框架介绍
  8. 装完linux无法进入windows,安装Ubuntu后无法启动Windows,如何解决?
  9. 如何在UltraCompare中编辑文件?
  10. 玩转数学答题赢大奖,福利抢先拿!
  11. Android Studio 插件整理
  12. android bootload漏洞,一加6手机的Bootloader漏洞可让攻击者控制设备
  13. java微信公众号开发一:服务器信息配置
  14. MW6MaxiCode ACX溢出
  15. 机器学习OneR算法
  16. 计算机网络培训方案,计算机网络技术 专业培训方案
  17. 前端多级组织(部门)结构展示
  18. 学习 Python 之 Pygame 开发魂斗罗(八)
  19. linux下查看mysql线程_linux-如何查看线程在哪个CPU内核中运行?
  20. UE4 什么是蓝图,如何用来快速创建原型?

热门文章

  1. python编程入门经典实例-【python】编程语言入门经典100例--30
  2. UVa12604 Caesar Cipher(kmp)
  3. 网络编程学习笔记(ICMPv6和IPv6套接口选项)
  4. HDU2093 考试排名
  5. Django 的模板语法之过滤器
  6. JavaSE学习笔记(二十九)—— 其它流
  7. Android学习笔记之Intent
  8. Spring学习----IoC容器创建对象
  9. 【Spring-web】RestTemplate源码学习——梳理内部实现过程
  10. 关于android开发添加菜单XML文件之后无法在R.java中生成ID的问题