欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Spring Cloud Config與Bus整合實(shí)現(xiàn)微服務(wù)配置自動刷新功能

 更新時間:2024年10月18日 15:01:26   作者:布說在見  
通過整合SpringCloud Config與Spring Cloud Bus,實(shí)現(xiàn)了微服務(wù)配置的自動刷新功能,這個機(jī)制允許一個微服務(wù)實(shí)例在配置更新時通過消息總線通知其他所有實(shí)例同步更新,從而保持配置的一致性并提升系統(tǒng)的運(yùn)維效率

Config與Bus整合自動刷新

微服務(wù)A的所有實(shí)例都通過Spring Cloud Bus消息總線連接到了一起,每個實(shí)例都會從Config Server訂閱配置更新事件并獲取配置信息。當(dāng)其中一個微服務(wù)節(jié)點(diǎn)的/ous/refresh端點(diǎn)被請求時,該實(shí)例就會向Spring Cloud Bus消息總線發(fā)送一個配置更新事件,其他實(shí)例通過Spring Cloud Bus消息總線獲得該事件后也會從Config Server獲取最新的配置信息并更新配置。

步驟:

1.安裝RabbitMQ并啟動

2.添加依賴

3.修改配置文件

4.改造Config Client

5.測試運(yùn)行

步驟1:安裝RabbitMQ并啟動 RabbitMQ的安裝

1.下載erlang,原因在于RabbitMQ服務(wù)端代碼是使用并發(fā)式語言erlang編寫的,下載地址:erlang,雙擊.eerlangxe文件進(jìn)行安裝就好,安裝完成之后創(chuàng)建一個名為ERLANG_HOME的環(huán)境變量,其值指向erlang的安裝目錄,同時將%ERLANG_HOME%\bin加入到Path中。

最后打開cmd命令行,輸入erl,如果出現(xiàn)erlang的版本信息就表示erlang語言環(huán)境安裝成功

2.下載RabbitMQ,下載地址:RabbitMQ,同樣雙擊.exe進(jìn)行安裝就好(注意:默認(rèn)的安裝目錄是C:/Program Files/…,這個目錄中是存在空格符的,我們需要改變安裝目錄,貌似RabbitMQ安裝目錄中是不允許有空格的)。

3.安裝RabbitMQ-Plugins,這個相當(dāng)于是一個管理界面,方便我們在瀏覽器界面查看RabbitMQ各個消息隊列以及exchange的工作情況,安裝方法是:打開命令行cd進(jìn)入rabbitmq的sbin目錄,輸入:rabbitmq-plugins enable rabbitmq_management命令,稍等會會發(fā)現(xiàn)出現(xiàn)plugins安裝成功的提示,默認(rèn)是安裝6個插件。

4.插件安裝完之后,在瀏覽器輸入http://localhost:15672進(jìn)行驗(yàn)證,你會看到下面界面,輸入用戶名:guest,密碼:guest 就可以進(jìn)入管理界面。

步驟2:創(chuàng)建項(xiàng)目

Eureka Server,config-server,config-client

創(chuàng)建Eureka Server

1)使用Spring Initializr方式創(chuàng)建一個名稱為eureka-server的Spring Boot項(xiàng)目,將Artifact命名為eureka-server,在pom.xml文件中添加Eureka Server依賴。

方便測試效果,新建一個eureka-server項(xiàng)目作為Config Server的注冊中心,
將eureka-server端口號設(shè)置為8761。

在加載不出來添加,要與springboot版本相符

<?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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.6.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.bushuo</groupId>
    <artifactId>eureka-server</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>eureka-server</name>
    <description>Demo project for Spring Boot</description>
    <url/>
    <licenses>
        <license/>
    </licenses>
    <developers>
        <developer/>
    </developers>
    <scm>
        <connection/>
        <developerConnection/>
        <tag/>
        <url/>
    </scm>
    <properties>
        <java.version>1.8</java.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>
                spring-cloud-starter-netflix-eureka-server
            </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>
    </dependencies>
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>Finchley.SR2</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>
</project>

2):添加Eureka的相關(guān)配置

在全局配置文件application.yml中添加Eureka的相關(guān)配置信息。

fetch-registry:
設(shè)置false 時,該Eureka客戶端不會從Eureka Server獲取服務(wù)注冊表的信息。這意味著它不會嘗試?yán)∑渌?wù)的信息,通常這在自身就是Server的情況下使用。register-with-eureka:
設(shè)置為 false 時,Eureka 客戶端不注冊到 Eureka Server。即不將自身信息注冊到服務(wù)注冊表。在 Eureka Server 節(jié)點(diǎn)配置中常用,因 Eureka Server 本身無需注冊到其他 Eureka Server,單實(shí)例時是。

3):在項(xiàng)目啟動類添加@EnableEurekaServer注解

在項(xiàng)目啟動類EurekaServerApplication上添加@EnableEurekaServer注解開啟Eureka Server功能。

4)測試運(yùn)行 http://localhost:8761

創(chuàng)建config-server

在config-4下創(chuàng)建config-server,添加依賴,添加配置,在啟動類添加注解

可以參考操作
依賴

配置bootstrap

添加啟動類注解

步驟3: 添加依賴

Config Server和Config Client與Spring Cloud Bus整合實(shí)現(xiàn)配置自動刷新。改造Config Server與Config Client,在各自的pom.xml配置文件中添加spring-cloud-starter-bus-amqp依賴實(shí)現(xiàn)配置自動更新與spring-boot-starter-actuator依賴監(jiān)控系統(tǒng)健康情況的工具。

        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-bus-amqp</artifactId>
         <version>2.0.0.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-actuator</artifactId>
    </dependency>

修改配置文件

改造Config Server和Config Client的配置文件,在配置文件中設(shè)置rabbitmq屬性的相關(guān)配置,包括主機(jī)地址、端口號、用戶名和密碼,如下所示。

spring:
  application:
    name: config-client
  cloud:
    config:
      server:
        git:
          uri: https://gitee.com/nobyebye/hello.git
          username: #自己的gitee用戶名
          password: #密碼
          label: master
  profiles:
    active: dev
  rabbitmq:
    host: localhost
    port: 5672
    username: guest
    password: guest
server:
  port: 8001
management:
  endpoints:
    web:
      exposure:
        include: "bus-refresh"

步驟4:Config Client

config-client的bootstrap.yml

添加控制器

Config Client,在需要動態(tài)刷新配置的類ConfigClientApplication上加上注解@RefreshScope。

要在gitee的配置文件添加foo,不然沒有注解

步驟5:測試運(yùn)行

依次啟動config-server、config-client項(xiàng)目。啟動成功后,使用瀏覽器訪問http://localhost:8002/foo

打開cmd輸入命令:curl -X POST http://localhost:8769/actuator/bus-refresh。

實(shí)現(xiàn)Config與Bus整合自動刷新后,系統(tǒng)能做到實(shí)時檢測配置變更并自動應(yīng)用,無需額外的人工干預(yù),減少了系統(tǒng)中斷時間和重啟操作。這不僅提高了系統(tǒng)的穩(wěn)定性,還能顯著提升運(yùn)維和開發(fā)的效率。

問題一

idea運(yùn)行多個端口,沒有services的窗口,點(diǎn)擊edit Configurations

點(diǎn)擊Templates->+ springboot,apply,ok了

窗口出來了

問題二

整合Bus自動刷新改進(jìn)了之前的什么問題?

手動刷新繁瑣:以往配置更新后需要手動重啟各服務(wù)實(shí)例,耗時且麻煩。自動刷新可以省去這一過程,讓更新更簡單快捷。

減少服務(wù)中斷:手動重啟會導(dǎo)致短暫的服務(wù)中斷。自動刷新避免了重啟,提升了服務(wù)的連續(xù)性和可用性。

配置一致性:手動更新可能導(dǎo)致不同實(shí)例間配置不一致,帶來同步問題。自動刷新確保所有實(shí)例同步更新,保持一致性。

降低運(yùn)維復(fù)雜性:自動刷新減少了手動操作,降低運(yùn)維負(fù)擔(dān),避免人為失誤。

提高實(shí)時性:配置更新可實(shí)時應(yīng)用,服務(wù)能更快地響應(yīng)變化,提高了系統(tǒng)的適應(yīng)性和靈活性。

總結(jié)

通過整合Spring Cloud Config與Bus實(shí)現(xiàn)配置自動刷新,可以在無需重啟服務(wù)的情況下更新微服務(wù)配置。該機(jī)制減少了運(yùn)維干預(yù),提升了系統(tǒng)的穩(wěn)定性和運(yùn)維效率,尤其在快速變更的環(huán)境中十分實(shí)用。

到此這篇關(guān)于Spring Cloud Config與Bus整合實(shí)現(xiàn)微服務(wù)配置自動刷新的文章就介紹到這了,更多相關(guān)Spring Cloud Config微服務(wù)配置自動刷新內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java服務(wù)器端跨域問題解決方案

    Java服務(wù)器端跨域問題解決方案

    這篇文章主要介紹了java服務(wù)器端跨域問題解決方案,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-01-01
  • 解決Mybatis中result標(biāo)簽識別不了的情況

    解決Mybatis中result標(biāo)簽識別不了的情況

    這篇文章主要介紹了解決Mybatis中result標(biāo)簽識別不了的情況,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教。
    2022-01-01
  • SpringBoot整合MOTT動態(tài)讀取數(shù)據(jù)庫連接信息并連接MQTT服務(wù)端

    SpringBoot整合MOTT動態(tài)讀取數(shù)據(jù)庫連接信息并連接MQTT服務(wù)端

    MQTT是一種輕量級的消息傳輸協(xié)議(Message Queuing Telemetry Transport),旨在實(shí)現(xiàn)設(shè)備之間的低帶寬和高延遲的通信,本文給大家介紹了SpringBoot整合MOTT動態(tài)讀取數(shù)據(jù)庫連接信息并連接MQTT服務(wù)端,需要的朋友可以參考下
    2024-04-04
  • idea中創(chuàng)建jsp項(xiàng)目的詳細(xì)實(shí)戰(zhàn)步驟

    idea中創(chuàng)建jsp項(xiàng)目的詳細(xì)實(shí)戰(zhàn)步驟

    才學(xué)javaWeb,以防自己忘記創(chuàng)建項(xiàng)目的過程,所以淺淺的記錄一下吧,下面這篇文章主要給大家介紹了關(guān)于idea中創(chuàng)建jsp項(xiàng)目的詳細(xì)步驟,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09
  • Springboot整合Socket實(shí)現(xiàn)單點(diǎn)發(fā)送,廣播群發(fā),1對1,1對多實(shí)戰(zhàn)

    Springboot整合Socket實(shí)現(xiàn)單點(diǎn)發(fā)送,廣播群發(fā),1對1,1對多實(shí)戰(zhàn)

    本文主要介紹了Springboot整合Socket實(shí)現(xiàn)單點(diǎn)發(fā)送,廣播群發(fā),1對1,1對多實(shí)戰(zhàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • 關(guān)于Controller 層返回值的公共包裝類的問題

    關(guān)于Controller 層返回值的公共包裝類的問題

    本文給大家介紹Controller 層返回值的公共包裝類-避免每次都包裝一次返回-InitializingBean增強(qiáng),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2021-09-09
  • java中hashmap容量的初始化實(shí)現(xiàn)

    java中hashmap容量的初始化實(shí)現(xiàn)

    這篇文章主要介紹了java中hashmap容量的初始化實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • 推薦兩款java開發(fā)實(shí)用工具 hutool 和 lombok

    推薦兩款java開發(fā)實(shí)用工具 hutool 和 lombok

    通過本文給大家推薦兩款java開發(fā)實(shí)用工具 hutool 和 lombok,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2021-04-04
  • java 中InputStream,String,File之間的相互轉(zhuǎn)化對比

    java 中InputStream,String,File之間的相互轉(zhuǎn)化對比

    這篇文章主要介紹了java 中InputStream,String,File之間的相互轉(zhuǎn)化對比的相關(guān)資料,需要的朋友可以參考下
    2017-04-04
  • Java線程池Executor用法詳解

    Java線程池Executor用法詳解

    本文主要為大家詳細(xì)介紹了Java線程池Executor的用法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08

最新評論