前言:
必需学会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