其實可以改善的地方還有配置中心…這個部分
所以需要補足的地方有
所以需要補足的地方有
- 配置中心
- 監控中心
- 自動化部屬
- 容器可視化
- 分布式事務管理
- 對象儲存
- 主從複製
- redis集群
Spring Cloud Bus
今天來補足配置中心這個功能
Spring Cloud Config 简介
SpringCloudConfig就是我们通常意义上的配置中心,把应用原本放在本地文件的配置抽取出来放在中心服务器,从而能够提供更好的管理、发布能力。SpringCloudConfig分服务端和客户端,服务端负责将git svn中存储的配置文件发布成REST接口,客户端可以从服务端REST接口获取配置。但客户端并不能主动感知到配置的变化,从而主动去获取新的配置,这需要每个客户端通过POST方法触发各自的/refresh。
Spring Cloud Config 简介
SpringCloudConfig就是我们通常意义上的配置中心,把应用原本放在本地文件的配置抽取出来放在中心服务器,从而能够提供更好的管理、发布能力。SpringCloudConfig分服务端和客户端,服务端负责将git svn中存储的配置文件发布成REST接口,客户端可以从服务端REST接口获取配置。但客户端并不能主动感知到配置的变化,从而主动去获取新的配置,这需要每个客户端通过POST方法触发各自的/refresh。
SpringCloudBus通过一个轻量级消息代理连接分布式系统的节点。这可以用于广播状态更改(如配置更改)或其他管理指令。SpringCloudBus提供了通过POST方法访问的endpoint/bus/refresh,这个接口通常由git的钩子功能调用,用以通知各个SpringCloudConfig的客户端去服务端更新配置。
注意:这是工作的流程图,实际的部署中SpringCloudBus并不是一个独立存在的服务,这里单列出来是为了能清晰的显示出工作流程。
下图是SpringCloudConfig结合SpringCloudBus实现分布式配置的工作流
data:image/s3,"s3://crabby-images/db44d/db44d103f5ce133e4ec469ec8b77ffc5dc3c9f26" alt=""
SpringCloudConfig结合SpringCloudBus实现分布式配置的工作流
Config Server
新增依賴
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-server</artifactId>
</dependency>
服務註冊
package com.example.demo;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.config.server.EnableConfigServer;
@EnableConfigServer
@SpringBootApplication
public class EurekaServiceConfigApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaServiceConfigApplication.class, args);
}
}
新增配置
application.yml
eureka:
client:
serviceUrl:
#總服務的 地址
defaultZone: http://localhost:8761/eureka/
spring:
application:
name: config-server
cloud:
config:
label: master
server:
git :
uri : https://github.com/x213212/SpringCloudConfig.git
search-paths : /
server:
port: 9112
#spring.cloud.config.server.git.username=your username
#spring.cloud.config.server.git.password=your password
上傳至 github
data:image/s3,"s3://crabby-images/01f6d/01f6d4e81bad530d88a32b05fcb56a575dabac20" alt=""
data:image/s3,"s3://crabby-images/1de51/1de51f969c2ce581dea5da46045e03fdfceae238" alt=""
data:image/s3,"s3://crabby-images/01f6d/01f6d4e81bad530d88a32b05fcb56a575dabac20" alt=""
data:image/s3,"s3://crabby-images/1de51/1de51f969c2ce581dea5da46045e03fdfceae238" alt=""
content=hello-dev
data:image/s3,"s3://crabby-images/3b387/3b387e5d74fa0bc0adf7139fbcab3c74d4e683a6" alt=""
{"name":"springCloudConfig","profiles":["dev"],"label":"master","version":"9193e63725e5fa3f274a7d07dee5f040c054c7a7","state":null,"propertySources":[{"name":"https://github.com/x213212/SpringCloudConfig.git/application-dev.properties","source":{"content":"hello-dev"}}]}
證明配置服務中心可以從git倉庫獲取訊息
http請求位置與對應路徑如下:
http請求位置與對應路徑如下:
/{application}/{profile}[/{label}]
/{application}-{profile}.yml
/{label}/{application}-{profile}.yml
/{application}-{profile}.properties
/{label}/{application}-{profile}.properties
Config Client
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-client</artifactId>
</dependency>
服務註冊
package com.example.demo;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
@SpringBootApplication
public class EurekaServiceConfigClientApplication {
@Value("${content}")
String content;
@RequestMapping("/")
public String home() {
return "content:" + content;
}
public static void main(String[] args) {
SpringApplication.run(EurekaServiceConfigClientApplication.class, args);
}
}
新增配置
問題
Caused by: java.lang.IllegalArgumentException: Could not resolve placeholder ‘content’ in value “${content}”
Caused by: java.lang.IllegalArgumentException: Could not resolve placeholder ‘content’ in value “${content}”
application.properties
spring.application.name=spring-cloud-config-client
server.port=7020
application.yml
spring :
application:
name : spring-cloud-config-client
server :
port : 7020
bootstrap.properties
#spring.cloud.config.server.git.username=your username
#spring.cloud.config.server.git.password=your password
spring.cloud.config.name=client
spring.cloud.config.profile=dev
spring.cloud.config.uri=http://localhost:9112/
spring.cloud.config.label=master
data:image/s3,"s3://crabby-images/53b20/53b201b00d81ccc5bb838a4aa1ba64ea78260edf" alt=""
結合Eureka Provider
透過 post 刷新微服務節點配置檔
Config Client
- EurekaServiceProvider
- EurekaServiceProvider2
data:image/s3,"s3://crabby-images/fb6f6/fb6f6a743a5551814bc5bc5dc761e236903de8e3" alt=""
Provider
@Value("${content}")
String content;
@Value("${server.port}")
String serverport ;
@RequestMapping("/gitconfig")
public String gitconfig() {
return "Hello world ,port:" + serverport+",content="+content;
}
EurekaServiceFeignConsumer HomeClient
@GetMapping("/gitconfig")
public String gitconfig() ;
EurekaServiceFeignConsumer ConsumerController
@GetMapping("/gitconfig")
public String gitconfig() {
String message = homeClient.gitconfig();
logger.info("[eureka-fegin][ConsumerController][hello], message={}", message);
// log.info("[eureka-ribbon][EurekaRibbonConntroller][syaHello], message={}", message);
return message ;
}
data:image/s3,"s3://crabby-images/6fe87/6fe8748f11b68ec39e19b9c06d5ac45364eeada6" alt=""
登入
data:image/s3,"s3://crabby-images/a1b60/a1b6003d679ab32949cb8cbe906e8960afd8ee18" alt=""
data:image/s3,"s3://crabby-images/87c62/87c622bfdee053f3734d3ee50d8442a7d77e5a12" alt=""
以上修改玩git 配置檔後 我們的 provider 要重啟才能獲取配置檔案
下面我們來分兩種方法
一種是透過 post 去刷新
一種是透過我們的 Spring cloud bus 去刷新我們的配置檔案
手動觸發更新配置檔案
安全認證
management.security.enabled=false
新增依賴
<!-- actuator 监控 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-client</artifactId>
</dependency>
開啟refresh
@RefreshScope
在程序的启动类 EurekaProviderApplication 通过 @RefreshScope 开启 SpringCloudConfig 客户端的 refresh 刷新范围,来获取服务端的最新配置,@RefreshScope要加在声明@Controller声明的类上,否则refresh之后Conroller拿不到最新的值,会默认调用缓存。
@RefreshScope
@SpringBootApplication
@EnableEurekaClient
@RestController
//@EnableSwagger2
data:image/s3,"s3://crabby-images/1f56d/1f56d9ab4d8f9c7cee669f188b56ff9387ac8912" alt=""
更新git
data:image/s3,"s3://crabby-images/0a370/0a370e8e4c1b564033c41e67552b741bc54da4f1" alt=""
可以透過 postman 去戳api
http://localhost:8081/refresh,http://localhost:8083/refresh
手動刷新
data:image/s3,"s3://crabby-images/9c48d/9c48d6538d7795d288100b6f75102310beaeda82" alt=""
2.0之前
2.0之以后
curl -v -X POST “http://localhost:8081/actuator/bus-refresh”
curl -X POST “http://localhost:8081/actuator/bus-refresh”
————————————————
版权声明:本文为CSDN博主「bigDataShare」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/sdrfengmi/java/article/details/86622556
data:image/s3,"s3://crabby-images/98a20/98a2092e3179bab17df0a73b0dcce929fe986845" alt=""
curl -X POST “http://localhost:8081/actuator/bus-refresh”
————————————————
版权声明:本文为CSDN博主「bigDataShare」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/sdrfengmi/java/article/details/86622556
data:image/s3,"s3://crabby-images/98a20/98a2092e3179bab17df0a73b0dcce929fe986845" alt=""
Spring Cloud Bus update
手動更新
rabbitmq 來透過 spring cloud bus 去 更新我們的 配置檔
Spring Cloud Bus 將分佈式系統的節點通過輕量級消息代理連接起來。用於在集群中傳播狀態更改(例如配置更改事件)或其他管理指令。 Spring Cloud Bus 的一個核心思想是通過分佈式的啟動器對 Spring Boot 應用進行擴展,也可以用來建立一個或多個應用之間的通信頻道。目前唯一實現的方式是用 AMQP 消息代理作為通道,但是相同的基本功能集(還有一些取決於傳輸)在其他傳輸的路線圖上
Spring Cloud Bus 將分佈式系統的節點通過輕量級消息代理連接起來。用於在集群中傳播狀態更改(例如配置更改事件)或其他管理指令。 Spring Cloud Bus 的一個核心思想是通過分佈式的啟動器對 Spring Boot 應用進行擴展,也可以用來建立一個或多個應用之間的通信頻道。目前唯一實現的方式是用 AMQP 消息代理作為通道,但是相同的基本功能集(還有一些取決於傳輸)在其他傳輸的路線圖上
消息總線
消息總線是一種通信工具,可以在機器之間互相傳輸消息、文件等。消息總線扮演著一種消息路由的角色,擁有一套完備的路由機制來決定消息傳輸方向。發送段只需要向消息總線發出消息而不用管消息被如何轉發。
Spring cloud bus 通過輕量消息代理連接各個分佈的節點。管理和傳播所有分佈式項目中的消息,本質是利用了MQ的廣播機制在分佈式的系統中傳播消息,目前常用的有Kafka和RabbitMQ 。
下面是一個配置中心刷新配置的例子
消息總線是一種通信工具,可以在機器之間互相傳輸消息、文件等。消息總線扮演著一種消息路由的角色,擁有一套完備的路由機制來決定消息傳輸方向。發送段只需要向消息總線發出消息而不用管消息被如何轉發。
Spring cloud bus 通過輕量消息代理連接各個分佈的節點。管理和傳播所有分佈式項目中的消息,本質是利用了MQ的廣播機制在分佈式的系統中傳播消息,目前常用的有Kafka和RabbitMQ 。
下面是一個配置中心刷新配置的例子
data:image/s3,"s3://crabby-images/c6923/c69238127cbcc0d990f0724a19f98e0b4d3c173c" alt=""
架構圖
[圖片來源於網絡如有侵權請私信刪除]
1、提交代碼觸發post請求給bus/refresh
2、server端接收到請求並發送給Spring Cloud Bus
3、Spring Cloud bus接到消息並通知給其它客戶端
4、其它客戶端接收到通知,請求Server端獲取最新配置
5、全部客戶端均獲取到最新的配置
2、server端接收到請求並發送給Spring Cloud Bus
3、Spring Cloud bus接到消息並通知給其它客戶端
4、其它客戶端接收到通知,請求Server端獲取最新配置
5、全部客戶端均獲取到最新的配置
Config Server
新增依賴
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>
新增配置檔
bootstrap.properties
management.security.enabled=false
application.yml
eureka:
client:
serviceUrl:
#總服務的 地址
defaultZone: http://localhost:8761/eureka/
spring:
application:
name: config-server
cloud:
config:
label: master
server:
git :
uri : https://github.com/x213212/SpringCloudConfig.git
search-paths : /
rabbitmq:
addresses: 192.168.99.100:5672
password: guest
username: guest
server:
port: 9112
#spring.cloud.config.server.git.username=your username
#spring.cloud.config.server.git.password=your password
去rabbitmq看看
data:image/s3,"s3://crabby-images/dcacb/dcacb9aeaba75d682aad5a323057e4a0529369b8" alt=""
data:image/s3,"s3://crabby-images/dcacb/dcacb9aeaba75d682aad5a323057e4a0529369b8" alt=""
Config Client
新增依賴
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>
新增配置檔
bootstrap.properties
management.security.enabled=false
application.yml
# Config Server
# 新增依賴
```xml
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>
新增配置檔
application.yml
注意zipkin 與 外層 rabbitmq
注意zipkin 與 外層 rabbitmq
eureka:
client:
serviceUrl:
defaultZone: http://localhost:8761/eureka/
register-with-eureka : true
spring:
application:
name: eureka-provider
zipkin:
base-url: http://192.168.99.100:9411
sender:
type: rabbit
rabbitmq:
addresses: 192.168.99.100:5672
password: guest
username: guest
queue: zipkin
rabbitmq:
addresses: 192.168.99.100:5672
password: guest
username: guest
management:
security:
enabled : false
server:
port: 8071
服務啟動
data:image/s3,"s3://crabby-images/796ce/796ce8118ae6b35590c0f29dbfe06c1e71bef79c" alt=""
正常來說 有三個
Config Server
和 兩個 provider
data:image/s3,"s3://crabby-images/cbe37/cbe372ae0f146d9e7b996b8ced77a9dc967926f4" alt=""
初始狀態
data:image/s3,"s3://crabby-images/fd83d/fd83db011495332af8e6004637ca5e1b674461db" alt=""
中間跑去除錯 405 找不到 method
Config server 修正配置檔
eureka:
client:
serviceUrl:
defaultZone: http://localhost:8761/eureka/
register-with-eureka : true
spring:
application:
name: eureka-provider
zipkin:
base-url: http://192.168.99.100:9411
sender:
type: rabbit
rabbitmq:
addresses: 192.168.99.100:5672
password: guest
username: guest
queue: zipkin
rabbitmq:
addresses: 192.168.99.100:5672
password: guest
username: guest
management:
security:
enabled : false
endpoints:
web:
exposure:
include: bus-refresh
endpoint:
bus-refresh:
enabled: true
server:
port: 8072
Config client 修正配置檔
eureka:
client:
serviceUrl:
defaultZone: http://localhost:8761/eureka/
register-with-eureka : true
spring:
application:
name: eureka-provider
zipkin:
base-url: http://192.168.99.100:9411
sender:
type: rabbit
rabbitmq:
addresses: 192.168.99.100:5672
password: guest
username: guest
queue: zipkin
rabbitmq:
addresses: 192.168.99.100:5672
password: guest
username: guest
management:
security:
enabled : false
endpoints:
web:
exposure:
include: bus-refresh
endpoint:
bus-refresh:
enabled: true
server:
port: 8072
post 觸發刷新
舊版spring cloud bus
data:image/s3,"s3://crabby-images/29136/291365407003c3f81b1f5560a0646e516ce5620b" alt=""
data:image/s3,"s3://crabby-images/323de/323ded2afa3f0c03ecfa9b53705f9424ed1bbb93" alt=""
可以看到配置檔 已經更改
data:image/s3,"s3://crabby-images/aa137/aa1378a53c3a2ea0a46cb327cbb524576e4c4c75" alt=""
data:image/s3,"s3://crabby-images/aa137/aa1378a53c3a2ea0a46cb327cbb524576e4c4c75" alt=""
透過 github webhook 去觸發更新
在更早之前的時候 我們在串接facebook api 或者是 line api 有看過 webhook
就是 git 去觸發我們的 rabbitmq 更新
抄起我們的 ngork 代理一下 9122 端口
data:image/s3,"s3://crabby-images/1f54c/1f54cbb7d2d60554025152aaa2ca42f439cecb3b" alt=""
data:image/s3,"s3://crabby-images/d82ec/d82ecba731ad9efe420873eef272a3816fe00bed" alt=""
data:image/s3,"s3://crabby-images/c37c7/c37c7861c15532c252114a525fdca094c4046fc7" alt=""
data:image/s3,"s3://crabby-images/0e147/0e147377b7f5ee004eba5dc9511950079b9173d5" alt=""
data:image/s3,"s3://crabby-images/131c7/131c7f95a83fd016a684c1ece0b3d0b0c659b1aa" alt=""
就是 git 去觸發我們的 rabbitmq 更新
抄起我們的 ngork 代理一下 9122 端口
data:image/s3,"s3://crabby-images/1f54c/1f54cbb7d2d60554025152aaa2ca42f439cecb3b" alt=""
data:image/s3,"s3://crabby-images/d82ec/d82ecba731ad9efe420873eef272a3816fe00bed" alt=""
data:image/s3,"s3://crabby-images/c37c7/c37c7861c15532c252114a525fdca094c4046fc7" alt=""
data:image/s3,"s3://crabby-images/0e147/0e147377b7f5ee004eba5dc9511950079b9173d5" alt=""
data:image/s3,"s3://crabby-images/131c7/131c7f95a83fd016a684c1ece0b3d0b0c659b1aa" alt=""
github webhhok error
重寫 config server /refresh
RefreshController
@RestController
public class RefreshController {
@RequestMapping("/refresh")
public void refresh(){
RestTemplate restTemplate = new RestTemplate();
HttpHeaders httpHeaders = new HttpHeaders();
httpHeaders.add(HttpHeaders.CONTENT_TYPE,"application/json");
HttpEntity<MultiValueMap<String, String>> request = new HttpEntity<>(null,httpHeaders);
ResponseEntity<String> stringResponseEntity = restTemplate.postForEntity("http://localhost:9112/actuator/bus-refresh",
request, String.class);
}
}
data:image/s3,"s3://crabby-images/05be5/05be50860dcec1c53f9028d64782848a11050733" alt=""
data:image/s3,"s3://crabby-images/c8a1e/c8a1e94cb21ccdfe2e4bcbacf2b55c6753c737d7" alt=""
data:image/s3,"s3://crabby-images/998ee/998eebf7dd968e107b8a39f20895d2a4776dfce8" alt=""
成功完成刷新!
局部刷新
某些場景下(例如灰度發布),我們可能只想刷新部分微服務的配置,此時可通過http://localhost:9112/actuator/bus-refresh 端點的destination參數來定位要刷新的應用程序。
data:image/s3,"s3://crabby-images/190b0/190b06723c061e559657b3e516c9c365a7975398" alt=""
data:image/s3,"s3://crabby-images/190b0/190b06723c061e559657b3e516c9c365a7975398" alt=""
例如:/actuator/bus-refresh?destination=customers:8000,這樣消息總線上的微服務實例就會根據destination參數的值來判斷是否需要要刷新。其中,customers:8000指的是各個微服務的ApplicationContext ID。
data:image/s3,"s3://crabby-images/d6679/d6679d4b5ec16ad8c2de0a5081b135a5d7132291" alt=""
data:image/s3,"s3://crabby-images/d6679/d6679d4b5ec16ad8c2de0a5081b135a5d7132291" alt=""
destination參數也可以用來定位特定的微服務。例如:/actuator/bus-refresh?destination=eureka-provider:**,這樣就可以觸發eureka-provider微服務所有實例的配置刷新。
我們的 微服務就暫時告一段落了,先來研究一下論文