三种部署模式

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%\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版本已经可以用于生产环境,在此之前的版本,请勿在生产上使用。

参考资料

  • 部署手册
  • 集群部署说明

推荐阅读

  • Nacos系列:欢迎来到Nacos的世界!
  • Nacos系列:基于Nacos的注册中心
  • Nacos系列:基于Nacos的配置中心
  • Nacos系列:Nacos的Java SDK使用

Nacos系列:Nacos的三种部署模式相关推荐

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

    三种部署模式 Nacos支持三种部署模式 1.单机模式:可用于测试和单机使用,生产环境切忌使用单机模式(满足不了高可用) 2.集群模式:可用于生产环境,确保高可用 3.多集群模式:可用于多数据中心场景 ...

  2. Nacos支持三种部署模式

    Nacos支持三种部署模式 Nacos支持三种部署模式 单机模式 - 用于测试和单机试用. 集群模式 - 用于生产环境,确保高可用. 多集群模式 - 用于多数据中心场景. 单机模式下运行Nacos L ...

  3. Azkaban 的三种部署模式是什么?

    前言 本文隶属于专栏<1000个问题搞定大数据技术体系>,该专栏为笔者原创,引用请注明来源,不足和错误之处请在评论区帮忙指出,谢谢! 本专栏目录结构和参考文献请见1000个问题搞定大数据技 ...

  4. 吸顶wifi_分享 | 酒店WiFi网络的三种部署模式

    酒店的无线网络,在酒店部署移动网络业务的时候,很多酒店会发现实际效果远达不到预期.酒店员工和入住用户经常会抱怨无线网络不稳定.视频无限缓冲中.经常掉线--,那么今天我们来了解酒店无线网络的部署.一.影 ...

  5. 有几种部署模式_来!PyFlink 作业的多种部署模式

    关于 PyFlink 的博客我们曾介绍过 PyFlink 的功能开发,比如,如何使用各种算子(Join/Window/AGG etc.),如何使用各种 Connector(Kafka, CSV, So ...

  6. Solr系列二:solr-部署详解(solr两种部署模式介绍、独立服务器模式详解、SolrCloud分布式集群模式详解)...

    一.solr两种部署模式介绍 Standalone Server 独立服务器模式:适用于数据规模不大的场景 SolrCloud  分布式集群模式:适用于数据规模大,高可靠.高可用.高并发的场景 二.独 ...

  7. 云计算的五个基本特征、四种部署模型和三种服务模式

    五个基本特征 自助服务 使用者可以按需要获取云端的计算资源 广泛的网络访问 使用者可以随时随地使用云终端设备接入网络并使用云端的计算资源. 资源池化 计算资源汇集在一起,形成一个个CPU池.内存池等, ...

  8. 什么是云计算、云计算的特点、三种服务模式、四种部署模式

    什么是云计算? 云计算是一种技术架构,随着当前技术的发展,应用提供商需要处理的计算量越来越大,意味着应用提供商需要扩充自己的服务器.存储等一系列设备来支撑自己的服务,成本也随之上升.于是,云计算的概念 ...

  9. efm8bb1 烧录器_【技术】 EFM8BB1系列MCU三种工作模式详解

    MCU,该MCU最高运行频率可达25MHz, 其RAM容量最大为512B,FLASH容量最大可达8KB. EFM8BB1集成了丰富的外设资源,其内部集成12 bit A/D转换器,最高转换速率可达80 ...

最新文章

  1. signal---高级信号注册函数
  2. tomcat的jdbc连接池PoolExhaustedException
  3. linux ftrace原理
  4. Error Code: 1052. Column '列名' in where clause is ambiguous
  5. 在html用div怎样写页脚,使用div+CSS将页脚始终控制在页面最下方的方法
  6. twitter storm源码走读(二)
  7. poj 2823 单调队列
  8. bootstrap table 怎么实现前两列固定冻结?
  9. Java程序设计语言基础03:Java中的程序执行流程
  10. 注解 java 原理_Java注解基本原理
  11. python实现自动打电话软件_电销自动打电话app
  12. 电子签章在商业银行的应用取得重要进展,“6类”场景深化应用
  13. 【c4d学习笔记】对称方向不对的问题
  14. 安装VS2010 SP1失败,安装VS2010 SP1时出现回滚,
  15. 企业官方微博的视觉设计与营销策略分析
  16. nar-gab投稿记录
  17. 使用Raspberry Pi,DHT-22和OLED显示屏的ESP32 MicroPython MQTT教程
  18. 如何从零开发一个低代码平台,有哪些成熟技术组件可用
  19. 【蓝桥杯】 C++ 纸张尺寸
  20. ADI中文手册获取方法

热门文章

  1. 浅谈千万级PV/IP规模高性能高并发网站架构
  2. Ubuntu下安装配置Open×××
  3. 基于Python的频谱分析(一)
  4. 使用request实现网站中的注册功能
  5. spark-submit参数说明--standalone
  6. 简练软考知识点整理-控制干系人参与
  7. BZOJ 1874: [BeiJing2009 WinterCamp]取石子游戏(SG函数)
  8. bootstrapdatetimepicker 隐藏触发 bootstrap modal隐藏事件
  9. Web前端学习第七天·fighting_CSS样式的编写和使用(二)
  10. BNUOJ 6038 - Reaux! Sham! Beaux!(模拟)