Nacos系列:Nacos的三種部署模式

知行旅人發表於2019-02-24

三種部署模式

Nacos支援三種部署模式

1、單機模式:可用於測試和單機使用,生產環境切忌使用單機模式(滿足不了高可用)

2、叢集模式:可用於生產環境,確保高可用

3、多叢集模式:可用於多資料中心場景

單機模式

啟動 Nacos Server

Linux:sh startup.sh -m standalone Windows:cmd startup.cmd -m standalone 或 雙擊 startup.cmd 啟動

關閉 Nacos Server

Linux:sh shutdown.sh Windows:cmd shutdown.cmd 或 雙擊 shutdown.cmd 啟動

0.7版本之前,Nacos使用的是嵌入式資料庫Derby (Apache Derby)來儲存資料;0.7版本,增加了對mysql資料來源的支援。

Derby資料來源

內嵌的資料庫,通過命令直接啟動即可,無需額外安裝。

startup.cmd -m standalone
複製程式碼

MySQL資料來源

步驟一:安裝MySQL資料,版本要求:5.6.5+

步驟二:初始化資料庫

建立資料庫

create database if not exists nacos default charset utf8 collate utf8_general_ci;
複製程式碼

初始化資料庫 在nacos server解壓目錄conf下,找到 nacos-mysql.sql 檔案,直接執行,執行完成後,用Navicat客戶端檢視

Nacos系列:Nacos的三種部署模式

步驟三:修改conf/application.properties檔案,新增如下資訊

## mysql datasource
spring.datasource.platform=mysql 

db.num=1
db.url.0=jdbc:mysql://127.0.0.1:3306/nacos?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true
db.user=root
db.password=123456
複製程式碼

注意:spring.datasource.platform=mysql別漏了,要不然還是使用Derby資料庫。

步驟四:啟動 Nacos Server

啟動成功後,我們使用上一篇部落格:《Nacos系列:Nacos的Java SDK使用》的案例來驗證,執行NacosConfig,觀察資料表的內容變化,示例知行後,config_info表和his_config_info表都會有和配置相關的資料,如下圖所示:

Nacos系列:Nacos的三種部署模式

似乎Nacos的MySQL資料來源只儲存了配置資料,服務列表和註冊的服務例項資訊並不會出現在資料表中(通過執行示例中的NacosDiscovery類main()方法,就可以觀察到該現象)

叢集模式

資源有限,我直接在Windows上模擬部署搭建“偽叢集”, 新建一個檔案目錄NacosCluster,將Nacos Server解壓三份到該目錄下,分別命名為nasosSlave0、nasosSlave1、nasosSlave2,分配埠:8845、8846、8847

修改nasosSlave0/conf/application.properties,server.port=8845,並新增

## mysql datasource
spring.datasource.platform=mysql 

db.num=1
db.url.0=jdbc:mysql://127.0.0.1:3306/nacos?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true
db.user=root
db.password=123456
複製程式碼

這裡先使用一個MySQL庫演示功能,實際生產上至少要使用主備模式,例如:

db.num=2
db.url.0=jdbc:mysql://127.0.0.1:3306/nacos1?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true
db.url.1=jdbc:mysql://127.0.0.1:3306/nacos2?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true
db.user=root
db.password=123456
複製程式碼

拷貝nasosSlave0/conf/cluster.conf.example為cluster.conf,修改內容如下:

127.0.0.1:8845
127.0.0.1:8846
127.0.0.1:8847
複製程式碼

nasosSlave1、nasosSlave2 和 nasosSlave0 除了埠不同外,其它配置保持一致。

分別啟動每臺 Nacos Server

startup.cmd -m cluster
複製程式碼

注意:在Windows下,這個時候不能再雙擊startup.cmd啟動了,如果這樣啟動仍然是以單機模式執行,因為在bin/startup.cmd中有下面這段程式碼:

if not "%2" == "cluster" (
    set "JAVA_OPT=%JAVA_OPT% -Xms512m -Xmx512m -Xmn256m"
    set "JAVA_OPT=%JAVA_OPT% -Dnacos.standalone=true"
 ) else (
    set "JAVA_OPT=%JAVA_OPT% -server -Xms2g -Xmx2g -Xmn1g -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m"
    set "JAVA_OPT=%JAVA_OPT% -XX:-OmitStackTraceInFastThrow XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=%BASE_DIR%\logs\java_heapdump.hprof"
    set "JAVA_OPT=%JAVA_OPT% -XX:-UseLargePages"
 )
複製程式碼

觀察控制檯,啟動成功後,在控制檯可以看到如下資訊:

E:\Software\Nacos\nacosCluster\nacosSlave0\bin>startup.cmd -m cluster

         ,--.
       ,--.'|
   ,--,:  : |                                           Nacos 0.8.0
,`--.'`|  ' :                       ,---.               Running in cluster mode
|   :  :  | |                      '   ,'\   .--.--.    Port: 8845
:   |   \ | :  ,--.--.     ,---.  /   /   | /  /    '   Pid: 6568
|   : '  '; | /       \   /     \.   ; ,. :|  :  /`./   Console: http://192.168.1.102:8845/nacos/index.html
'   ' ;.    ;.--.  .-. | /    / ''   | |: :|  :  ;_
|   | | \   | \__\/: . ..    ' / '   | .; : \  \    `.      https://nacos.io
'   : |  ; .' ," .--.; |'   ; :__|   :    |  `----.   \
|   | '`--'  /  /  ,.  |'   | '.'|\   \  /  /  /`--'  /
'   : |     ;  :   .'   \   :    : `----'  '--'.     /
;   |.'     |  ,     .-./\   \  /            `--'---'
'---'        `--`---'     `----'

2019-02-20 23:06:13,059 INFO The server IP list of Nacos is [127.0.0.1:8845, 127.0.0.1:8846, 127.0.0.1:8847]

2019-02-20 23:06:14,185 INFO Nacos is starting...

2019-02-20 23:06:15,409 INFO Nacos is starting...

2019-02-20 23:06:16,512 INFO Nacos is starting...

2019-02-20 23:06:17,605 INFO Nacos is starting...

2019-02-20 23:06:18,736 INFO Nacos is starting...

2019-02-20 23:06:19,860 INFO Nacos is starting...

2019-02-20 23:06:21,021 INFO Nacos is starting...

2019-02-20 23:06:22,230 INFO Nacos is starting...

2019-02-20 23:06:23,390 INFO Nacos is starting...

2019-02-20 23:06:24,605 INFO Nacos is starting...

2019-02-20 23:06:25,991 INFO Nacos is starting...

2019-02-20 23:06:26,993 INFO Nacos is starting...

2019-02-20 23:06:28,197 INFO Nacos is starting...

2019-02-20 23:06:29,264 INFO Nacos is starting...

2019-02-20 23:06:30,515 INFO Nacos is starting...

2019-02-20 23:06:31,810 INFO Nacos is starting...

2019-02-20 23:06:32,934 INFO Nacos is starting...

2019-02-20 23:06:33,976 INFO Nacos is starting...

2019-02-20 23:06:35,044 INFO Nacos is starting...

2019-02-20 23:06:36,153 INFO Nacos is starting...

2019-02-20 23:06:37,290 INFO Nacos is starting...

2019-02-20 23:06:38,616 INFO Nacos is starting...

2019-02-20 23:06:39,736 INFO Nacos is starting...

2019-02-20 23:06:40,824 INFO Nacos is starting...

2019-02-20 23:06:41,757 INFO Nacos Log files: E:\Software\Nacos\nacosCluster\nacosSlave0\/logs/

2019-02-20 23:06:41,768 INFO Nacos Conf files: E:\Software\Nacos\nacosCluster\nacosSlave0\/conf/

2019-02-20 23:06:41,771 INFO Nacos Data files: E:\Software\Nacos\nacosCluster\nacosSlave0\/data/

2019-02-20 23:06:41,774 INFO Nacos started successfully in cluster mode.
複製程式碼

在瀏覽器分別訪問如下路徑 http://localhost:8845/nacos http://localhost:8846/nacos http://localhost:8847/nacos

如果都能訪問成功,證明叢集模式部署成功。

多叢集模式

Nacos支援NameServer路由請求模式,通過它您可以設計一個有用的對映規則來控制請求轉發到相應的叢集,在對映規則中您可以按名稱空間或租戶等分片請求(From Nacos官網)

其他說明

Nacos官方宣稱,Nacos v0.8.0 Pre-GA版本已經可以用於生產環境,在此之前的版本,請勿在生產上使用。

參考資料

推薦閱讀

相關文章