资讯专栏INFORMATION COLUMN

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

vibiu / 2846人阅读

摘要:数据源内嵌的数据库,通过命令直接启动即可,无需额外安装。参考资料部署手册集群部署说明推荐阅读系列欢迎来到的世界系列基于的注册中心系列基于的配置中心系列的使用

三种部署模式

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客户端查看

步骤三:修改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的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%logsjava_heapdump.hprof"
    set "JAVA_OPT=%JAVA_OPT% -XX:-UseLargePages"
 )

观察控制台,启动成功后,在控制台可以看到如下信息:

E:SoftwareNacos
acosCluster
acosSlave0in>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:SoftwareNacos
acosCluster
acosSlave0/logs/

2019-02-20 23:06:41,768 INFO Nacos Conf files: E:SoftwareNacos
acosCluster
acosSlave0/conf/

2019-02-20 23:06:41,771 INFO Nacos Data files: E:SoftwareNacos
acosCluster
acosSlave0/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版本已经可以用于生产环境,在此之前的版本,请勿在生产上使用。

参考资料

部署手册

集群部署说明

推荐阅读

Nacos系列:欢迎来到Nacos的世界!

Nacos系列:基于Nacos的注册中心

Nacos系列:基于Nacos的配置中心

Nacos系列:Nacos的Java SDK使用

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/73412.html

相关文章

  • Nacos系列:欢迎来到Nacos的世界!

    摘要:元数据数据如配置和服务描述信息,如服务版本权重容灾策略负载均衡策略鉴权配置各种自定义标签,从作用范围来看,分为服务级别的元信息集群的元信息及实例的元信息。 什么是Nacos? Nacos 是构建以服务为中心的现代应用架构 (例如微服务范式、云原生范式) 的服务基础设施。 Nacos可以做什么? 1、动态配置服务:支持以中心化、外部化和动态化的方式管理所有环境的配置。动态配置消除了配置变...

    waruqi 评论0 收藏0
  • docker部署单机nacos

    摘要:部署拉取镜像创建文件夹创建工作目录创建日志目录创建配置文件创建配置文件对应参数说明模式模式地址是否支持服务器端口多网卡下的自定义服务器支持主节点主节点端口主节点数据库数据库用户名数据库密码从节点从节点端口数据库数量部署 Nacos1、拉取镜像docker pull nacos/nacos-server2、创建nacos文件夹创建naocs工作目录: mkdir /usr/data/nacos...

    Tecode 评论0 收藏0
  • Spring Cloud Alibaba基础教程:Nacos的数据持久化

    摘要:在搭建集群之前,我们需要先修改的数据持久化配置为存储。所以,如果启动多个默认配置下的节点,数据存储是存在一致性问题的。为了解决这个问题,采用了集中式存储的方式来支持集群化部署,目前只要支持的存储。 前情回顾: 《Spring Cloud Alibaba基础教程:使用Nacos实现服务注册与发现》 《Spring Cloud Alibaba基础教程:支持的几种服务消费方式》 《Spri...

    endiat 评论0 收藏0
  • Nacos 1.0.0 功能预览

    摘要:去除了服务的健康检查模式之前服务的健康检查模式有三种和分别代表客户端上报服务端探测和取消健康检查。在模式下也不能编辑服务的元数据等非实例级别的数据,但是允许创建一个默认配置的服务。 Nacos 1.0.0 是正式 GA 的版本,在架构、功能和API设计上进行了全方位的重构和升级,1.0.0版本标志着Nacos的架构已经稳定,API列表最终确定。升级到1.0.0相比升级到其他版本,需要额...

    周国辉 评论0 收藏0

发表评论

0条评论

vibiu

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<