三種部署模式
Nacos支持三種部署模式
1、單機(jī)模式:可用于測試和單機(jī)使用,生產(chǎn)環(huán)境切忌使用單機(jī)模式(滿足不了高可用)
2、集群模式:可用于生產(chǎn)環(huán)境,確保高可用
3、多集群模式:可用于多數(shù)據(jù)中心場景
單機(jī)模式
啟動 Nacos Server
Linux:sh startup.sh -m standalone
Windows:cmd startup.cmd -m standalone 或 雙擊 startup.cmd 啟動
關(guān)閉 Nacos Server
Linux:sh shutdown.sh
Windows:cmd shutdown.cmd 或 雙擊 shutdown.cmd 啟動
在0.7版本之前,Nacos使用的是嵌入式數(shù)據(jù)庫Derby (Apache Derby)來存儲數(shù)據(jù);0.7版本,增加了對mysql數(shù)據(jù)源的支持。
Derby數(shù)據(jù)源
內(nèi)嵌的數(shù)據(jù)庫,通過命令直接啟動即可,無需額外安裝。
startup.cmd -m standalone
MySQL數(shù)據(jù)源
步驟一:安裝MySQL數(shù)據(jù),版本要求:5.6.5+
步驟二:初始化數(shù)據(jù)庫
創(chuàng)建數(shù)據(jù)庫
create database if not exists nacos default charset utf8 collate utf8_general_ci;
初始化數(shù)據(jù)庫
在nacos server解壓目錄conf下,找到 nacos-mysql.sql 文件,直接執(zhí)行,執(zhí)行完成后,用Navicat客戶端查看

步驟三:修改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數(shù)據(jù)庫。
步驟四:啟動 Nacos Server
啟動成功后,我們使用下一篇博客:《Nacos系列:Nacos的Java SDK使用》的案例來驗證,運(yùn)行NacosConfig,觀察數(shù)據(jù)表的內(nèi)容變化,示例知行后,config_info表和his_config_info表都會有和配置相關(guān)的數(shù)據(jù),如下圖所示:

似乎Nacos的MySQL數(shù)據(jù)源只存儲了配置數(shù)據(jù),服務(wù)列表和注冊的服務(wù)實例信息并不會出現(xiàn)在數(shù)據(jù)表中(通過運(yùn)行示例中的NacosDiscovery類main()方法,就可以觀察到該現(xiàn)象)
集群模式
資源有限,我直接在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庫演示功能,實際生產(chǎn)上至少要使用主備模式,例如:
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,修改內(nèi)容如下:
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啟動了,如果這樣啟動仍然是以單機(jī)模式運(yùn)行,因為在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路由請求模式,通過它您可以設(shè)計一個有用的映射規(guī)則來控制請求轉(zhuǎn)發(fā)到相應(yīng)的集群,在映射規(guī)則中您可以按命名空間或租戶等分片請求(From Nacos官網(wǎng))
其他說明
據(jù)Nacos官方宣稱,Nacos v0.8.0 Pre-GA版本已經(jīng)可以用于生產(chǎn)環(huán)境,在此之前的版本,請勿在生產(chǎn)上使用。
歡迎工作一到五年的Java工程師朋友們加入Java架構(gòu)開發(fā): 957734884,群內(nèi)提供免費(fèi)的Java架構(gòu)學(xué)習(xí)資料(里面有高可用、高并發(fā)、高性能及分布式、Jvm性能調(diào)優(yōu)、Spring源碼,MyBatis,Netty,Redis,Kafka,Mysql,Zookeeper,Tomcat,Docker,Dubbo,Nginx等多個知識點的架構(gòu)資料)合理利用自己每一分每一秒的時間來學(xué)習(xí)提升自己,不要再用"沒有時間“來掩飾自己思想上的懶惰!趁年輕,使勁拼,給未來的自己一個交代!