Nacos系列:Nacos的三种部署模式
三种部署模式
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的三种部署模式的更多相关文章
- tomcat-四种运行模式和三种部署模式(优化)
四中运行模式如下: 1-bio: 传统的Java I/O操作,同步且阻塞IO. 2-nio: JDK1.4开始支持,同步阻塞或同步非阻塞IO 3-aio(nio.2): JDK7开始支持,异步非阻塞I ...
- Intel系列微处理器的三种工作模式
body, table{font-family: 微软雅黑; font-size: 13.5pt} table{border-collapse: collapse; border: solid gra ...
- zookeeper有几种部署模式? zookeeper 怎么保证主从节点的状态同步?
一.zookeeper的三种部署模式 Zookeeper 有三种部署模式分别是单机模式.伪集群模式.集群模式.这三种模式在不同的场景下使用: 单机部署:一般用来检验 Zookeeper 基础功能,熟悉 ...
- ASP.NET MVC深入浅出系列(持续更新) ORM系列之Entity FrameWork详解(持续更新) 第十六节:语法总结(3)(C#6.0和C#7.0新语法) 第三节:深度剖析各类数据结构(Array、List、Queue、Stack)及线程安全问题和yeild关键字 各种通讯连接方式 设计模式篇 第十二节: 总结Quartz.Net几种部署模式(IIS、Exe、服务部署【借
ASP.NET MVC深入浅出系列(持续更新) 一. ASP.NET体系 从事.Net开发以来,最先接触的Web开发框架是Asp.Net WebForm,该框架高度封装,为了隐藏Http的无状态模 ...
- Solr系列二:solr-部署详解(solr两种部署模式介绍、独立服务器模式详解、SolrCloud分布式集群模式详解)
一.solr两种部署模式介绍 Standalone Server 独立服务器模式:适用于数据规模不大的场景 SolrCloud 分布式集群模式:适用于数据规模大,高可靠.高可用.高并发的场景 二.独 ...
- ubuntu上Hadoop三种运行模式的部署
Hadoop集群支持三种运行模式:单机模式.伪分布式模式,全分布式模式,下面介绍下在Ubuntu下的部署 (1)单机模式 默认情况下,Hadoop被配置成一个以非分布式模式运行的独立JAVA进程,适合 ...
- hadoop记录-[Flink]Flink三种运行模式安装部署以及实现WordCount(转载)
[Flink]Flink三种运行模式安装部署以及实现WordCount 前言 Flink三种运行方式:Local.Standalone.On Yarn.成功部署后分别用Scala和Java实现word ...
- IIS在ASP.NET Core下的两种部署模式
KestrelServer最大的优势体现在它的跨平台的能力,如果ASP.NET CORE应用只需要部署在Windows环境下,IIS也是不错的选择.ASP.NET CORE应用针对IIS具有两种部署模 ...
- 云计算的三种服务模式:SaaS/PaaS/IaaS
转载http://blog.chinaunix.net/uid-22414998-id-3141499.html 定义 云计算主要分为三种服务模式,而且这个三层的分法重要是从用户体验的角度出发的: S ...
随机推荐
- Spring核心
方法区与常量池 BeanFactoryPostProcessor与BeanPostProcessor使用 创建pc过程 https://www.liangzl.com/get-article-deta ...
- 简述Oracle IOT(Index Organized Table)
转:http://blog.itpub.net/17203031/viewspace-744477 对关系型数据库产品(RDBMS)而言,一个重要特性就是:数据信息都被组织为二维数据表,信息的表达可以 ...
- U-Boot Makefile分析(1)配置脚本mkconfig分析
我们在编译U-Boot之前,需要根据当前使用的板子进行配置,例如make s5p_goni_config,接着才能进行编译make.下面首先分析配置阶段U-Boot做了哪些事情. 由于执行这些命令是在 ...
- 微软develop apps在QQ上部分功能的实现
最近我对微软的develop apps的文档进行了简读,在感叹UWP在支持服务上的全面的同时,我不禁在在常用的APP上对于这些功能支持进行了部分的寻找对应.而我进行功能对照的,就是平时很常用的一款手机 ...
- Python Memo 赋值与ID (Assignment & id())
利用Python内置函数id()找出内部地址,探讨赋值与内建地址. id()的官方解释:this is the address of the object in memory 那么 a =1 是什么意 ...
- Python中用random产生随机数的用法
>>>random.randomrandom.random()用于生成一个0到1的随机符点数: 0 <= n < 1.0 >>>random.unifo ...
- unigui ShowModal、MessageDlg
procedure Calback(Sender: TComponent; AResult: Integer);procedure TForm.Calback(Sender: TComponent; ...
- 通过脚本下载GO被墙或常用的相关包
脚本描述 脚本依赖环境:Windows,GO,GIT 脚本将创建 temp 目录,并拷贝相关包到第一个 GOPATH 中 可将脚本保存到本地自行添加被墙或者常用的包 完整脚本代码 @echo off ...
- 【渗透攻防】千变万化的WebShell
前言WebShell就是以asp.php.jsp或者cgi等网页文件形式存在的一种命令执行环境,也可以将其称做为一种网页后门.本篇文章将带大家学习如何获取WebShell,如何隐藏WebShell,有 ...
- prompt的工作原理
浏览器提供了一个内置函数,可以用来获取用户输入:这个函数就是prompt.函数prompt与你使用过的函数alert很像(它也显示一个对话框,其中包含你指定的字符串),但它还提供了让用户输入响应的区域 ...