【SpringCloud 】第八篇: 消息总线(Spring Cloud Bus)
前言:
必需学会SpringBoot基础知识
简介:
spring cloud 为开发人员提供了快速构建分布式系统的一些工具,包括配置管理、服务发现、断路器、路由、微代理、事件总线、全局锁、决策竞选、分布式会话等等。它运行环境简单,可以在开发人员的电脑上跑。
工具:
JDK8
apache-maven-3.5.2
IntelliJ IDEA 2018.1 x64
Spring Cloud Bus 将分布式的节点用轻量的消息代理连接起来。它可以用于广播配置文件的更改或者服务之间的通讯,也可以用于监控。本文要讲述的是用Spring Cloud Bus实现通知微服务架构的配置文件的更改。
分析: 当git文件更改的时候,通过Postman –> Post 向端口为8882的eureka-config-client发送请求/bus/refresh/;此时8882端口会发送一个消息,由消息总线向其他服务传递,从而使整个微服务集群都达到更新配置文件。
一、准备工作
首先, 需要安装 rabbitMq 点击rabbitmq下载, (如果不会安装的查看我写的教程: CentOS下安装RabbitMQ教程)
二、改造 eureka-config-client –> pom.xml –> spring-cloud-starter-bus-amqp
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion> <groupId>com.lwc</groupId>
<artifactId>eureka-config-client</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging> <name>eureka-config-client</name>
<description>Demo project for Spring Boot</description> <parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.10.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent> <properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
<spring-cloud.version>Edgware.SR3</spring-cloud.version>
</properties> <dependencies>
<dependency>
<groupId>org.springframework.retry</groupId>
<artifactId>spring-retry</artifactId>
</dependency>
<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.boot</groupId>
<artifactId>spring-boot-starter-aop</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-test</artifactId>
<scope>test</scope>
</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>
</dependencies> <dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement> <build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build> <repositories>
<repository>
<id>spring-milestones</id>
<name>Spring Milestones</name>
<url>https://repo.spring.io/milestone</url>
<snapshots>
<enabled>false</enabled>
</snapshots>
</repository>
</repositories> </project>
在配置文件bootstrap-dev.yml中加上RabbitMq的配置,包括RabbitMq的地址、端口,用户名、密码,代码如下:
server:
port: 8882
eureka:
client:
serviceUrl:
defaultZone: http://localhost:8889/eureka/
spring:
cloud:
config:
label: master
profile: local
discovery:
serviceId: eureka-config-server
enabled: true
rabbitmq:
username: your username
password: your password
host: your host
port: 5672
management:
security:
enabled: false
如果rabbitmq有用户名密码,输入即可。
依次启动eureka-config-server-cluster、eureka-config-server,启动两个eureka-config-client,端口为:8881、8882。
访问http://localhost:8881/url 或者 http://localhost:8882/url 浏览器显示:
http://www.cnblogs.com/EddieBlog/
重要环节: 正常情况下在代码仓库修改了数值, 是需要重启服务才能达到配置文件更新, 如何解决这种尴尬的情况呢?
只需要发送 POST 请求:http://localhost:8881/bus/refresh 就会重新加载:
这时我们再访问http://localhost:8881/url 或者http://localhost:8882/url 浏览器显示:
http://www.cnblogs.com/EddieBlog/p/8724912.html
提示:
/bus/refresh接口可以指定服务,即使用”destination”参数,比如 “/bus/refresh?destination=customers:**” 即刷新服务名为customers的所有服务,不管 IP Addr
还有一种方式: eureka-config-server, N个eureka-config-client
1. 在 eureka-config-server 添加依赖 2. 在 eureka-config-server 写入 rabbitmq 配置 3. client 端不需要做什么修改, 如果真的需要的话,加上 management.security.enabled=false ,防止不能够刷新。 4. POSTMAN TEST
三、源码下载:
标签 8-1
https://github.com/eddie-code/SpringCloudDemo
最新文章
- JDBC的操作总结
- js基础篇——localStorage使用要点
- Android 隐式意图激活另外一个Actitity
- golang的";...";备忘
- 查看,添加和删除GIT配置的正确姿势
- javaScript函数提升及作用域
- 学习Tensorflow,使用源码安装
- eclipse导出svn源码,如何转化为项目
- 什么是CRUD
- Liferay7 BPM门户开发之16: Liferay中用户\站点\组织架构\角色\用户组以及关联关系
- Android使用AIDL跨进程通信
- sql特殊语法
- C# 连接Oracle时报错的问题
- 【ARM】arm系列知识框架
- day43 数据库学习egon的博客 视图、触发器、事务、存储过程、函数
- Eigen教程(5)
- webpack9--删除冗余的CSS
- 使用js 文件参数 以及IHttpModule实现服务验证asp.net 版的初步实现
- Python2 long() 函数
- jsp 的 3 个编译指令