注:此文不适合0基础学习者直接阅读,请先完整的将作者关于微服务的博文全部阅读一遍,如果还有疑问,可以再来阅读此文,地址:http://blog.csdn.net/sosfnima/article/details/53178157,推荐读者去找作者的书籍《Spring Cloud微服务实战》进行详细的学习

序:

接着上一篇博文《Spring Cloud构建微服务架构(二)分布式配置中心》往下说,上一篇博文中,我们分析了分布式配置中心如何去git仓中读取配置信息,以及客户端如何去获取配置信息。但是,之前的分析都是需要人工手动维护的,假如我们有100个集群服务,难道我们要通过手动去分别维护这些信息吗?这样维护的成本太太了,此篇文章则是对上一篇博文的延续,希望通过一次维护,整个集群中所有服务进行动态更新,大大简化维护成本。其实,这就是我经常说的热部署,即不需要重启服务器就可以更新系统配置。

 消息中线我借助了服务注册与发现进行简化配置,具体不清楚的可以参照《Spring Cloud构建微服务架构(一)服务注册与发现》一文。

消息中间件rabbitMQ:

目前,spring  cloud  bus消息总线集成了两种中间件,分别是rabbitMQ以及Kafka。而我们项目组用的是rabbitMQ,因此我这一篇的消息总线主要是基于rabbitMQ展开叙述的,至于rabbitMQ的安装和说明,请参照《Spring Boot中使用RabbitMQ》 一文。

按照上一篇博文配置,其实现原理结构图如下:

而按此篇博文进行配置,其实现结构如如下:

对比两张图,好处一目了然。

修改配置中心服务器:

我们公司已经安装好了一套完整的rabbitMQ环境,因此我就基于此服务进行说明:

上一篇文章中,我们说到了两个服务,一个是分布式配置中心服务器(config-server),还有一个是分布式配置中心客户端(zuul_serviceA、zuul_serviceC),这里两个客户端代码,除了端口不一样,其他内容一模一样,你们可以将按照上一篇构建的客户端程序复制一份,改下服务名以及端口号即可。

首先将config-server配置文件application.properties修改成如下:

#这些是之前的配置
spring.application.name=configServer
server.port=7001
eureka.client.serviceUrl.defaultZone=http://localhost:8081/eureka/ spring.cloud.config.server.git.uri=http://10.10.10.236/spring/cloud-config.git
spring.cloud.config.server.git.searchPaths=cloud-config-repo

#由此往下是后添加的RabbitMQ配置信息
management.security.enabled=false
spring.rabbitmq.host=10.10.10.201
spring.rabbitmq.port=5672
spring.rabbitmq.username=guest
spring.rabbitmq.password=guest

添加依赖包:

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency> <dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka</artifactId>
</dependency> <!-- 配置中心依赖包 -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-server</artifactId>
</dependency> <!-- 消息总线依赖包 -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency> <!-- 消息总线依赖包 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

主程序:

package com.net;

import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.builder.SpringApplicationBuilder;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.config.server.EnableConfigServer; @EnableDiscoveryClient
@EnableConfigServer
@SpringBootApplication
public class App
{
public static void main( String[] args )
{
new SpringApplicationBuilder(App.class).web(true).run(args);
}
}

将配置中心注册到eureka中,这样后面的客户端服务zuul_serviceA、zuul_serviceC等等,就可以简化配置了,具体的信息在后面说;

至此,我们就可以说已经将消息总线与配置中心进行了整合,此时放在后面说。

修改配置中心客户端

以zuul_serviceA为例,其他服务具体操作和本服务一致。

添加依赖包:

<!-- eureka服务注册 -->
<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-test</artifactId>
<scope>test</scope>
</dependency> <dependency>
<groupId>c3p0</groupId>
<artifactId>c3p0</artifactId>
<version>0.9.1.2</version>
</dependency> <dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-config</artifactId>
</dependency> <!-- 消息总线rabbitMQ -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>
<!-- 消息总线必须模块,用来刷新端点 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency> <dependency>
<groupId>org.springframework.retry</groupId>
<artifactId>spring-retry</artifactId>
</dependency> <dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
</dependency>

修改配置文件bootstrap.properties:

spring.application.name=ServiceA
server.port=2001 #spring.cloud.config.hostname=127.0.0.1
#spring.cloud.config.uri=http://${spring.cloud.config.hostname}:${config.port:7001}
#spring.cloud.config.name=lz-hr
#spring.cloud.config.profile=aaa,bbb #add bus later
eureka.client.serviceUrl.defaultZone=http://localhost:8081/eureka/
spring.cloud.config.discovery.enabled=true
spring.cloud.config.discovery.serviceId=configServer
spring.cloud.config.name=lz-hr
spring.cloud.config.profile=bbb,aaa
spring.cloud.config.failFast=true #spring cloud bus
management.security.enabled=false
spring.rabbitmq.host=10.10.10.201
spring.rabbitmq.port=5672
spring.rabbitmq.username=guest
spring.rabbitmq.password=guest

至此,rabbitMQ在配置中心服务端与客户端全部配置完毕。

下面一次启动eurake服务、config-server服务,zuul_serviceA服务以及zuul_serviceC,查看配置注册中心信息:

下面分别查看zuul_serviceA服务以及zuul_serviceC服务对应的界面信息:

下面对git仓中的lz-hr-bbb.properties文件中的bbb属性进行修改:

按照 上一篇博文《Spring Cloud构建微服务架构(二)分布式配置中心》配置,要分别取刷新zuul_serverA和zuul_serverC,假如有100个服务,那就要去刷100次,维护成本巨大。

而按照此篇博文配置,只需要刷新其中一个客户端服务即可,其他的服务自动进行刷新,大大降低了维护成本。

下面刷新zuul_serverA服务,然后分别查看zuul_serverA服务于zuul_serverC服务,结果查看的信息都是最新的:

注:刷新URL工具为 fiddler

Spring Cloud构建微服务架构(三)消息总线的更多相关文章

  1. Spring Cloud构建微服务架构

    Dalston版本 由于Brixton和Camden版本的教程已经停止更新,所以笔者计划在2017年上半年完成Dalston版本的教程编写(原计划完成Camden版本教程,但由于写了两篇Dalston ...

  2. 《Spring Cloud构建微服务架构》系列博文示例

    SpringCloud-Learning   源码下载地址:http://download.csdn.net/detail/k21325/9650968     本项目内容为Spring Cloud教 ...

  3. Spring Cloud构建微服务架构(二)服务消费者

    Netflix Ribbon is an Inter Process Communication (IPC) cloud library. Ribbon primarily provides clie ...

  4. Spring Cloud构建微服务架构:服务网关(路由配置)【Dalston版】

    转载:http://blog.didispace.com/spring-cloud-starter-dalston-6-2/ 原创  2017-08-26  翟永超  Spring Cloud 被围观 ...

  5. Cola Cloud 基于 Spring Boot, Spring Cloud 构建微服务架构企业级开发平台

    Cola Cloud 基于 Spring Boot, Spring Cloud 构建微服务架构企业级开发平台: https://gitee.com/leecho/cola-cloud

  6. Spring Cloud构建微服务架构(五)服务网关

    通过之前几篇Spring Cloud中几个核心组件的介绍,我们已经可以构建一个简略的(不够完善)微服务架构了.比如下图所示: 我们使用Spring Cloud Netflix中的Eureka实现了服务 ...

  7. Spring Cloud构建微服务架构 - 服务网关

    通过之前几篇Spring Cloud中几个核心组件的介绍,我们已经可以构建一个简略的(不够完善)微服务架构了.比如下图所示: alt 我们使用Spring Cloud Netflix中的Eureka实 ...

  8. 第1章 Spring Cloud 构建微服务架构(一)服务注册与发现

      一.Spring Cloud 简介 Spring Cloud是一个基于Spring Boot实现的云应用开发工具,它为基于JVM的云应用开发中的配置管理.服务发现.断路器.智能路由.微代理.控制总 ...

  9. Spring Cloud构建微服务架构(一)服务注册与发现

    Spring Cloud简介 Spring Cloud是一个基于Spring Boot实现的云应用开发工具,它为基于JVM的云应用开发中的配置管理.服务发现.断路器.智能路由.微代理.控制总线.全局锁 ...

随机推荐

  1. Codeforces Round #431 (Div. 2) C

    From beginning till end, this message has been waiting to be conveyed. For a given unordered multise ...

  2. 服务器配置,负载均衡时需配置MachineKey

    服务器配置,负载均衡时需配置MachineKey https://blog.csdn.net/liuqiao0327/article/details/54018922 Asp.Net应用程序中为什么要 ...

  3. 企业级Web Nginx 服务优化

    企业级Web Nginx 服务优化 http://blog.51cto.com/search/result?q=%E4%BC%81%E4%B8%9A%E7%BA%A7Web+Nginx+%E6%9C% ...

  4. 机器学习框架ML.NET学习笔记【9】自动学习

    一.概述 本篇我们首先通过回归算法实现一个葡萄酒品质预测的程序,然后通过AutoML的方法再重新实现,通过对比两种实现方式来学习AutoML的应用. 首先数据集来自于竞赛网站kaggle.com的UC ...

  5. mysql非常全的和完整的总结

    (1)数据类型 类型 备注 tinyint/smallint/mediumint/int/bigint 1B/2B/3B/4B/8B float/double 单精度/双精度浮点型 decimal 不 ...

  6. jdk1.6与jdk1.7list集合排序区别与算法

    源码分析: 在Collections.sort中:    public static <T extends Comparable<? super T>> void sort(L ...

  7. Eclipse的安装与使用

    1安装 下载 http://www.eclipse.org 安装 (最好下载解压版的,不用安装) 安装目录中,不要出现空格与中文 例如,解压到:D:\codetool 2项目的创建 双击运行.exe文 ...

  8. for循环操作DOM缓存节点长度?

    不管是在网上,还是在翻看书籍的时候,都能看到在使用for循环操作DOM节点时要做数节点长度的缓存,以确保性能最优化! 这二种写法格式大致是下面这样的 /*节点集合*/ var domarr=docum ...

  9. 就来推荐一本2018年研究的Web书《移动Web前端高效开发实战》

    一线互联网公司Web前端团队实战经验总结,涵盖移动Web前端开发各个关键技术环节,包括移动开发核心技术.常用布局方案.MV*类新时代框架.预编译技术.性能优化.开发调试.混合式应用.单元测试.工程化等

  10. Google Play发布App中遇到"多个APK:版本1未提供给任何设备配置使用。"问题的解决方法

    在google play上发布apk,当上传了apk文件,填写了相关的内容信息和介绍图片.图标后,出现“发布应用”始终灰色无法点击,查看原因显示如下问题: 其中支持的设备数量始终显示为0,怀疑是编译出 ...