Nacos集群部署方案

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 920 13:57 nacos8849
drwxr-xr-x 9 root root 122 920 13:57 nacos8850
drwxr-xr-x 9 root root 122 920 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的集群已经启动成。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值