91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Nacos配置管理的示例分析

發布時間:2021-12-08 09:49:08 來源:億速云 閱讀:150 作者:小新 欄目:云計算

這篇文章主要介紹了Nacos配置管理的示例分析,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

硬編碼

配置項作為類字段的形式存在,如:

public class AppConfig {    private int connectTimeoutInMills = 5000;    public int getConnectTimeoutInMills() {        return connectTimeoutInMills;
    }    public void setConnectTimeoutInMills(int connectTimeoutInMills) {        this.connectTimeoutInMills = connectTimeoutInMills;
    }
}

這種形式主要有三個問題:

如果配置是需要動態修改的話,需要當前應用去暴露管理該配置項的接口,至于是 Controller 的 API 接口,還是 JMX ,都是可以做到。

另外,配置變更都是發生在內存中,并沒有持久化。因此,在修改配置之后重啟應用,配置又會變回代碼中的默認值了,這是一個坑啊,筆者就曾經掉進去過,爬了好一會才上岸。

最后一個問題,就是當你有多臺機器的時候,要修改一個配置,每一臺都得去操作一遍,運維成本可想而知,極其蛋疼。

配置文件

Spring 中常見的 properties、yml 文件,或其他自定義的,如,“conf”后綴等:

# application.propertiesconnectTimeoutInMills=5000

相比“硬編碼”的形式,它解決了第二個問題,持久化了配置。但是,另外兩個問題并沒有解決,運維成本依舊還是很高的。

配置動態變更,可以是通過類似“硬編碼”暴露管理接口的方式,這時,代碼中會多一步持久化新配置到文件的邏輯。或者,簡單粗暴點,直接登錄機器上去修改配置文件,再重啟應用,讓配置生效。當然,你也可以在代碼中增加一個定時任務,如每隔 10s 讀取配置文件內容,讓最新的配置能夠及時在應用中生效,這樣也就免去了重啟應用這個“較重”的運維操作。

通過增加“持久化邏輯”、“定時任務”讓“配置文件”的形式比“硬編碼”前進了一小步。

DB 配置表

這里的 DB 可以是 MySQL 等的關系型數據庫,也可以是 Redis 等的非關系型數據庫。數據表如:

CREATE TABLE `config` (  `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,  `key` varchar(50) NOT NULL DEFAULT '' COMMENT '配置項',  `value` varchar(50) NOT NULL DEFAULT '' COMMENT '配置內容',  `updated_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,  `created_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
  PRIMARY KEY (`id`),  UNIQUE KEY `idx_key` (`key`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='配置信息';INSERT INTO `config` (`key`, `value`, `updated_time`, `created_time`) VALUES ('connectTimeoutInMills', '5000', CURRENT_TIMESTAMP, CURRENT_TIMESTAMP);

它相對于前兩者,更進一步,將配置從應用中抽離出來,集中管理,能較大的降低運維成本。

那么,它能怎么解決動態更新配置的問題呢?據我所知,有兩種方式。

其一,如同之前一樣,通過暴露管理接口去解決,當然,也一樣得增加持久化的邏輯,只不過,之前是寫文件,現在是將最新配置寫入數據庫。不過,程序中還需要有定時從數據庫讀取最新配置的任務,這樣,才能做到只需調用其中一臺機器的管理配置接口,就能把最新的配置下發到整個應用集群所有的機器上,真正達到降低運維成本的目的。

其二,直接修改數據庫,程序中通過定時任務從數據庫讀取最新的配置內容。

“DB 配置表”的形式解決了主要的問題,但是它不夠優雅,帶來了一些“累贅”。

Nacos 配置管理

Nacos 真正將配置從應用中剝離出來,統一管理,優雅的解決了配置的動態變更、持久化、運維成本等問題。

應用自身既不需要去添加管理配置接口,也不需要自己去實現配置的持久化,更不需要引入“定時任務”以便降低運維成本。Nacos 提供的配置管理功能,將配置相關的所有邏輯都收攏,并且提供簡單易用的 SDK,讓應用的配置可以非常方便被 Nacos 管理起來。

如果是在 Spring 中使用 Nacos,只需三個步驟即可:

  • 添加依賴

<dependency>
    <groupId>com.alibaba.nacos</groupId>
    <artifactId>nacos-spring-context</artifactId>
    <version>${latest.version}</version>
</dependency>
  • 添加 @EnableNacosConfig 注解啟用 Nacos Spring 的配置管理服務。以下示例中,我們使用 @NacosPropertySource 加載了 dataId 為 example 的配置源,并開啟自動更新:

@Configuration
@EnableNacosConfig(globalProperties = @NacosProperties(serverAddr = "127.0.0.1:8848"))
@NacosPropertySource(dataId = "example", autoRefreshed = true)
public class NacosConfiguration {
}
  • 通過 Spring 的 @Value 注解設置屬性值。

注意:需要同時有 Setter方法才能在配置變更的時候自動更新。

public class AppConfig {
    @Value("${connectTimeoutInMills:5000}")
    private int connectTimeoutInMills;
    public int getConnectTimeoutInMills() {
        return connectTimeoutInMills;
    }
    public void setConnectTimeoutInMills(int connectTimeoutInMills) {
        this.connectTimeoutInMills = connectTimeoutInMills;
    }
}

感謝你能夠認真閱讀完這篇文章,希望小編分享的“Nacos配置管理的示例分析”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

阿尔山市| 韶关市| 西城区| 巴林右旗| 涿鹿县| 柘城县| 桂东县| 蕲春县| 东港市| 海安县| 美姑县| 彰武县| 许昌县| 三穗县| 茌平县| 云和县| 宜州市| 博野县| 吴旗县| 石屏县| 太谷县| 南皮县| 神农架林区| 宣武区| 桑日县| 当阳市| 霸州市| 淮北市| 万州区| 澳门| 会理县| 松原市| 新源县| 莆田市| 治县。| 威海市| 辉县市| 紫阳县| 招远市| 丹巴县| 孝感市|