Nacos 是阿里巴巴2018年7月份開源的項目,如其名, Naming Configuration Service ,專注於服務發現和配置管理領域。
Nacos 是什么?上面已經大概介紹了,更多詳細內容可以從 官網 或 Github 了解。
Nacos 能幫我們解決什么問題?本文圍繞其“配置管理”功能來解答。
配置,作為代碼如影隨形的小伙伴,伴隨着應用的整個生命周期,我們當然對它也非常的熟悉,想想配置一般都通過哪幾種形式存在?
- 硬編碼
- 配置文件
- DB 配置表
硬編碼
配置項作為類字段的形式存在,如:
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.properties
connectTimeoutInMills=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; } }
以上的三個步驟,對應用本身幾乎沒有任何的侵入,1 個依賴 2 注解,寥寥數行,就把配置通過 Nacos 管理起來了。
關於配置的動態更新,對 Nacos Spring 的用戶來說,在自身應用中就只是設置 “autoRefreshed” 的一個布爾值。然后在需要修改配置的時候,調用 Nacos 修改配置的接口,或使用 Nacos 的控制台去修改,配置發生變更后, Nacos 就會把最新的配置推送到該應用的所有機器上,簡單而高效。
Nacos單機搭建
1、首先安裝jdk
1.1、上傳jdk-8u111-linux-x64.tar.gz並解壓縮到/home/soft/jdk1.8.0_111
//jdk文件上傳到了/home/ftp目錄下
#tar -zxvf /home/ftp/jdk-8u111-linux-x64.tar.gz -C /home/soft
1.2、配置環境變量
//打開/etc/profile文件
# vim /etc/profile
在文件末尾插入如下內容
export JAVA_HOME=/home/soft/jdk1.8.0_111
export JRE_HOME=${JAVA_HOME}/jre
export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib
export PATH=${JAVA_HOME}/bin:$PATH
執行profile
#source /etc/profile
2、安裝Nacos
Step 1: Download the binary package
You can download the package from the latest stable release.
Take release nacos-server-0.9.0.zip for example.
unzip nacos-server-0.9.0.zip
cd nacos/bin
Step 2: Start Server
On the Linux/Unix/Mac platform, run the following command to start server with standalone mode:
sh startup.sh -m standalone
On the Windows platform, run the following command to start server with standalone mode. Alternatively, you can also double-click the startup.cmd to run NacosServer.
cmd startup.cmd -m standalone

