前言

上一章最后讲了,更新配置以后需要重启客户端才能生效,这在实际的场景中是不可取的。由于目前Steeltoe配置的重载只能由客户端发起,没有实现处理程序侦听服务器更改事件,所以还没办法实现彻底实现这一功能。这一章的例子,客户端的部分我们采用Java来实现。Steeltoe更新以后我会及时把 .Net Core的实现方式补全。

实际上也并不需要重启,客户端调用IConfigurationRoot.Reload()方法也可以实现这个功能,但是去请求客户端也不是一个好办法,因为N节点的配置中心客户端你没办法一一去调用。

[HttpGet("/reload")]public string Reload(){_config?.Reload();//刷新配置return _config?["name"];
}

代码部分

上一章我们一共创建了2个应用程序,一个配置中心服务端和一个配置中心客户端。在分布式场景中,任何单点都是有问题的,所以我们首先对其优化,两个配置中心服务端,三个配置中心客户端,并全部注册到服务中心。

创建配置中心服务端

首先还是创建一个服务中心的应用程序,参考第一章内容。
访问http://localhost:5000
打开网站返回表示创建服务中心成功。
然后创建配置中心服务端,参考第四章内容,我们通过修改配置文件来实现两个服务端。端口分别为5100,5200。
创建两个配置文件application-s1.properties,application-s2.properties

application-s1.properties
server.port=5100spring.application.name=config-server
spring.cloud.config.server.git.uri=https://github.com/longxianghui/configs.git#git用户名和密码#spring.cloud.config.server.git.username=xxx#spring.cloud.config.server.git.password=xxx#git仓库目录#spring.cloud.config.server.git.search-paths=xxx,xxx,xxxeureka.client.serviceUrl.defaultZone=http://localhost:5000/eureka/
application-s2.properties
server.port=5200spring.application.name=config-server
spring.cloud.config.server.git.uri=https://github.com/longxianghui/configs.git#git用户名和密码#spring.cloud.config.server.git.username=xxx#spring.cloud.config.server.git.password=xxx#git仓库目录#spring.cloud.config.server.git.search-paths=xxx,xxx,xxxeureka.client.serviceUrl.defaultZone=http://localhost:5000/eureka/

使用maven打包

然后在终端分别执行命令行

java -jar target/config-server-0.0.1-SNAPSHOT.jar --spring.profiles.active=s1
java -jar target/config-server-0.0.1-SNAPSHOT.jar --spring.profiles.active=s2

可以开多终端或者直接在Intellij IDEA里面运行

启动完成后分别执行
http://localhost:5100/demo/prod,
http://localhost:5200/demo/prod,
返回数据启动成功

创建配置中心客户端程序

使用IDEA创建spring boot程序

pom.xml
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-config</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-eureka</artifactId></dependency>
ConfigClientApplication.java
@SpringBootApplication@EnableDiscoveryClientpublic class ConfigClientApplication {public static void main(String[] args) {SpringApplication.run(ConfigClientApplication.class, args);}
}
Demo.java
@Component@ConfigurationProperties()public class Demo {private String name;    private Integer age;      private String env;    //get and set ...}
DemoController.java
@RestControllerpublic class DemoController {    @Autowiredprivate Demo demo;    @RequestMapping("demo")    public Demo demo() {        return demo;}
}

为了模拟集群效果我们创建3个配置文件

application-c1.properties
spring.application.name=config-client
server.port=5101
application-c2.properties
spring.application.name=config-client
server.port=5102
application-c3.properties
spring.application.name=config-client
server.port=5103

同时要非常注意的是,创建一个bootstrap.properties,这个配置在application配置之前启动,相关的spring cloud config的配置都需要加到这个配置文件里面,加到application配置文件里面无效

bootstrap.properties
spring.cloud.config.name=demo
spring.cloud.config.profile=dev#开启服务发现功能spring.cloud.config.discovery.enabled=true#服务idspring.cloud.config.discovery.serviceId=config-server#服务中心地址eureka.client.serviceUrl.defaultZone=http://localhost:5000/eureka/

打包代码分别执行下面3行命令

java -jar target/config-client-0.0.1-SNAPSHOT.jar --spring.profiles.active=c1
java -jar target/config-client-0.0.1-SNAPSHOT.jar --spring.profiles.active=c2
java -jar target/config-client-0.0.1-SNAPSHOT.jar --spring.profiles.active=c2

先访问http://localhost:5000/,服务都注册成功。

分别访问
http://localhost:5101/demo
http://localhost:5102/demo
http://localhost:5103/demo

能够正常的访问数据了,但是如果我们修改git的配置信息,配置中心客户端并不会主动获取新的配置信息。我们想一下有没有办法当我们提交配置信息后通知给所有客户端呢?说到通知大家马上就想到了消息队列,通知多客户端的模式,是不是就是消息队列里面的广播模式?想明白这点我们继续看下面的内容,继续改造我们的程序。spring cloud config提供了消息队列模式,通过调用提供的REST接口来通知到客户端来更新配置。
首先安装rabbitmq
我们继续改造配置中心的服务端和客户端
服务端和客户端的配置一样

pom.xml 添加mq的扩展
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-bus-amqp</artifactId></dependency>
application.properties 添加mq的配置信息
spring.rabbitmq.host=localhost
spring.rabbitmq.port=5672spring.rabbitmq.username=guest
spring.rabbitmq.password=guest
management.security.enabled=false

分别启动这5个服务(2个服务端,3个客户端)
修改demo-dev.yml
name: mickey2017并提交到github
rabbitmq提供了一个REST地址来刷新mq通知客户端。我们通过postman或者命令行来模拟post提交:http://localhost:5100/bus/refresh

这里调用5200也是可以的,调用客户端的3个端口一样可以 (http://localhost:5101/bus/refresh) ,前面说了调用客户端是不可取的,所以我们调用服务端的地址。
最后访问http://localhost:5101/demo

后记

通过这一章内容我们我们成功的改造了配置中心,实际的开发场景,我们总不能更新了配置就手动去模拟post提交吧?所以我们可以借助git的webhook功能,当提交代码以后就给配置中心服务端发送请求。再想深入一点,配置中心服务端不对外网暴露呀?那么我们可以用过通过Api网关来访问,同时使用服务发现的方式,又解决了要指定具体配置中心地址的问题。

最近群里面总有同学问授权的问题,那么我们下一章讲微服务下的Api授权。

示例代码

所有代码均上传github。代码按照章节的顺序上传,例如第一章demo1,第二章demo2以此类推。
求推荐,你们的支持是我写作最大的动力,我的QQ群:328438252,交流微服务。

相关文章:

  • 手把手教你使用spring cloud+dotnet core搭建微服务架构:服务治理(-)

  • spring cloud+dotnet core搭建微服务架构:服务发现(二)

  • spring cloud+dotnet core搭建微服务架构:Api网关(三)

  • 微服务~Eureka实现的服务注册与发现及服务之间的调用

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

原文地址:http://www.cnblogs.com/longxianghui/p/7687825.html


.NET社区新闻,深度好文,微信中搜索dotNET跨平台或扫描二维码关注

spring cloud+dotnet core搭建微服务架构:配置中心续(五)相关推荐

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

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

  2. spring cloud+dotnet core搭建微服务架构:Api网关(三)

    前言 国庆假期,一直没有时间更新. 根据群里面的同学的提问,强烈推荐大家先熟悉下spring cloud.文章下面有纯洁大神的spring cloud系列. 上一章最后说了,因为服务是不对外暴露的,所 ...

  3. spring cloud+dotnet core搭建微服务架构:服务发现(二)

    前言 上篇文章<手把手教你使用spring cloud+dotnet core搭建微服务架构:服务治理(-)>实际上只讲了服务治理中的服务注册,服务与服务之间如何调用呢?传统的方式,服务A ...

  4. 手把手教你使用spring cloud+dotnet core搭建微服务架构:服务治理(-)

    背景 公司去年开始使用dotnet core开发项目.公司的总体架构采用的是微服务,那时候由于对微服务的理解并不是太深,加上各种组件的不成熟,只是把项目的各个功能通过业务层面拆分,然后通过nginx代 ...

  5. spring cloud+.net core搭建微服务架构:Api授权认证(六)

    前言 这篇文章拖太久了,因为最近实在太忙了,加上这篇文章也非常长,所以花了不少时间,给大家说句抱歉.好,进入正题.目前的项目基本都是前后端分离了,前端分Web,Ios,Android...,后端也基本 ...

  6. 【译文】用Spring Cloud和Docker搭建微服务平台

    by Kenny Bastani Sunday, July 12, 2015 转自:http://www.kennybastani.com/2015/07/spring-cloud-docker-mi ...

  7. 用Spring Cloud和Docker搭建微服务平台

    This blog series will introduce you to some of the foundational concepts of building a microservice- ...

  8. .NET Core with 微服务 - Consul 配置中心

    上一次我们介绍了Elastic APM组件.这一次我们继续介绍微服务相关组件配置中心的使用方法.本来打算介绍下携程开源的重型配置中心框架 apollo 但是体系实在是太过于庞大,还是让我爱不起来.因为 ...

  9. Spring Cloud Alibaba 系统保护:微服务架构雪崩效应与服务限流

    前面我们介绍了 OpenFeign 微服务间通信与 Spring Cloud Gateway 网关通信,这些是日常业务中的正常处理情况,但是在微服务环境下受制于网络.机器性能.算法.程序各方面影响,运 ...

最新文章

  1. grep之字符串搜索算法Boyer-Moore由浅入深(比KMP快3-5倍)
  2. asp.net core json返回的时间格式出现T 如何解决
  3. Python将秒转换为 时分秒 的格式
  4. 「兼容M1」Royal TSX for Mac 最强远程管理软件
  5. poj 2387 Til the Cows Come Home dijkstra
  6. mysql select不走索引_避免写出不走索引的SQL, MySQL
  7. 130 行代码模仿火爆抖音的“蚂蚁呀嘿”特效,你学会了吗?
  8. 评测 | 千元以下的扫拖一体机器人,到底值不值得买?
  9. Google统治桌面再进一步 欲重走微软称霸之路
  10. high performance web sites 阅读小记
  11. Bailian4075 矩阵旋转【矩阵】
  12. matlab时频分析
  13. 关于电子计算机的热点,电脑如何变热点?8款电脑wifi热点软件推荐
  14. 基于改进的CASA模型反演NPP
  15. 平均销售额计算机公式,销售额是什么意思(销售额的基本计算公式)
  16. 链家租房数据基本分析
  17. html div边框宽度,边框的宽度
  18. Android OCR数字识别
  19. 魔百盒M301H-九联(JL)代工-强刷固件及教程
  20. 给JAVA初学者的建议(转载治phphot的一个牛人给java初学者的建议)

热门文章

  1. EntityFramework用法探索(三)CodeFirst流畅API
  2. 分布式服务下的关键技术(转)
  3. 使用XMLConfiguration解析xml,properties等相应信息
  4. ACM题解系列之一:刘汝佳:《算法竞赛入门经典》(第2版)
  5. vim学习日志(5):vim下wimrc的配置,解决中文乱码问题
  6. c++11新特性(4) lambda捕捉块
  7. MFC,QT与WinForm,WPF简介
  8. 为record类型自定义Equals方法
  9. ABP vNext微服务架构详细教程——身份管理服务
  10. .NET 6新特性试用 | Nuget包验证