1.介紹
生產環境中部署nacos首先肯定是使用集羣模式cluster保證高可用。
2.集羣部署架構圖
nacos 官方推薦用戶把所有服務列表放到一個vip下面,然後掛到一個域名下面
-
http://ip1:port/openAPI
直連ip模式,機器掛則需要修改ip纔可以使用。 -
http://VIP:port/openAPI
掛載VIP模式,直連vip即可,下面掛server真實ip,可讀性不好。 -
http://nacos.com:port/openAPI
域名 + VIP模式,可讀性好,而且換ip方便,推薦模式
官方推薦使用域名 + VIP模式
的集羣部署方案,所有我接下的演示都是基於此模式來實現的。
注意: 這裏的VIP直接使用 Nginx就可以實現了。
3.域名 + VIP模式集羣方案的實現
官方建議至少3個或3個以上的節點來實現集羣模式
。
因此我在本地搭建只有一臺機器,沒有使用虛擬機,所以通過修改端口的方式來部署這3個實例,端口分別爲:8851、8849、8850
3.1. 修改集羣配置
nacos
的conf目錄下有配置文件cluster.conf
,請每行配置成ip:port
。
192.168.10.200:8851
192.168.10.200:8849
192.168.10.200:8850
192.168.28.130是我本機ip,三個nacos實例都配置一樣即可
3.2. 配置 MySQL 數據庫
集羣模式必須使用MySQL
數據庫,生產使用建議至少主備模式
,或者採用高可用數據庫
。
3.2.1. 初始化 MySQL 數據庫
腳本在nacos的conf目錄下有配置文件nacos-mysql.sql
,直接執行即可
3.2.2. 添加數據庫配置
配置文件在nacos的conf目錄下的application.properties
,添加以下配置
db.num=1
db.url.0=jdbc:mysql://127.0.0.1:3306/nacos_config?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true
db.user=root
db.password=123456
- db.num 爲數據庫實例數量
- db.url.0 指定不同的數據庫連接
如果有多個數據庫實例通過 db.url.0、db.url.1… 指定不同的數據庫連接
3.3. 其他實例修改Nacos端口
修改nacos的conf目錄下application.properties
下的server.port
,三個實例分別爲:8851
、8849
、8850
下面是以8851爲例子:
# spring
server.contextPath=/nacos
server.servlet.contextPath=/nacos
server.port=8851
# nacos.cmdb.dumpTaskInterval=3600
# nacos.cmdb.eventTaskInterval=10
# nacos.cmdb.labelTaskInterval=300
# nacos.cmdb.loadDataAtStart=false
# metrics for prometheus
#management.endpoints.web.exposure.include=*
# metrics for elastic search
management.metrics.export.elastic.enabled=false
#management.metrics.export.elastic.host=http://localhost:9200
# metrics for influx
management.metrics.export.influx.enabled=false
#management.metrics.export.influx.db=springboot
#management.metrics.export.influx.uri=http://localhost:8086
#management.metrics.export.influx.auto-create-db=true
#management.metrics.export.influx.consistency=one
#management.metrics.export.influx.compressed=true
server.tomcat.accesslog.enabled=false
server.tomcat.accesslog.pattern=%h %l %u %t "%r" %s %b %D %{User-Agent}i
# default current work dir
server.tomcat.basedir=
nacos.security.ignore.urls=/,/**/*.css,/**/*.js,/**/*.html,/**/*.map,/**/*.svg,/**/*.png,/**/*.ico,/console-fe/public/**,/v1/auth/login,/v1/console/health/**,/v1/cs/**,/v1/ns/**,/v1/cmdb/**,/actuator/**,/v1/console/server/**
spring.datasource.platform=mysql
db.num=1
db.url.0=jdbc:mysql://127.0.0.1:3306/nacos_config?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true
db.user=root
db.password=123456
3.4. 啓動Nacos集羣
分別把3個實例都啓動起來,執行nacos的bin目錄下startup.sh
,該啓動文件默認就是集羣模式。
[root@flink nacos]# ll
總用量 0
drwxr-xr-x 9 root root 122 9月 20 13:57 nacos8849
drwxr-xr-x 9 root root 122 9月 20 13:57 nacos8850
drwxr-xr-x 9 root root 122 9月 20 13:56 nacos8851
3.5. 修改Nginx配置
修改conf/nginx.conf配置
upstream nacos {
server 192.168.28.130:8851;
server 192.168.28.130:8849;
server 192.168.28.130:8850;
}
server {
listen 80;
server_name nacos.a-hh.cn;
location / {
proxy_pass http://nacos;
}
}
配置域名nacos.a-hh.cn
綁定VIP
。
4.Nacos集羣管理
這時候一個leader和兩個follower的集羣已經啓動成。
參考資料
https://nacos.io/zh-cn/docs/cluster-mode-quick-start.html