Spring Cloud Alibaba 教程 | Nacos(六)
集群模式部署
前面我们已经学习了Nacos作为注册中心、配置中心的相关功能,但是我们之前启动Nacos是通过单实例模式启动的,只适合在学习和开发阶段,生产环境需要保证Nacos的高可用,所以今天我们来学习一下Nacos的集群模式部署。
官方推荐使用:http://nacos.com:port/openAPI 域名 + VIP模式搭建Nacos集群。
Nacos集群模式是需要两个条件的:
- 需要将Nacos数据持久化存储到Mysql数据库(单例模式默认使用了内嵌数据库)。
- 需要为集群的多个实例实现VIP功能(通常通过Nginx实现)。

使用Mysql存储数据
第一步:初始化mysql数据库。数据库版本要求5.6.5以上,数据库初始化文件为nacos-mysql.sql,存放在nacos的config目录里面。


第二步:修改conf/application.properties文件,增加支持mysql数据源配置(目前只支持mysql),添加mysql数据源的url、用户名和密码。
spring.datasource.platform=mysql
db.num=1
db.url.0=jdbc:mysql://192.168.0.205:3306/nacos?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true
db.user=root
db.password=123456

如果数据库有多个实例,可以按照下面配置方式添加多个Mysql实例
spring.datasource.platform=mysql
#数据库实例个数
db.num=2
# 第1个实例的地址
db.url.0=jdbc:mysql://11.162.196.16:3306/nacos_devtest?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true
# 第2个实例的地址
db.url.1=jdbc:mysql://11.162.196.17:3306/nacos_devtest?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true
db.user=nacos
db.password=123456
集群模式启动Nacos
集群模式至少需要两个Nacos实例才能维持,所以要保证Nacos高可用就必须至少要有三个实例。由于作者机器有限,我就在一台Linux机器192.168.0.127上启动三个不同端口的Nacos实例,在bin目录下对startup.sh文件复制出三个新的文件:
startup-8841.sh、startup-8842.sh、startup-8843.sh,并通过-Dserver.port参数指定应用运行端口。


接着复制conf目录下cluster.conf.example文件出一个新文件cluster.conf,并配置上所有集群节点的地址和端口信息,最后依次执行三个startup-xxx.sh脚本文件启动Nacos。(注意:不需要添加任何模式参数,将以集群模式启动)


启动之后Linux需要防火墙开放相应的三个服务端口,同时可以依次访问三个实例测试是否启动成功。
通过Nginx实现VIP
实现VIP的方式很多,这里我简单介绍一下使用Nginx实现集群模式的VIP功能。
关于如何安装Nginx可以参考这篇文章:https://www.runoob.com/linux/nginx-install-setup.html

安装好Nginx之后,修改conf目录下的nginx.conf文件,实现简单的VIP功能配置,最后启动Nginx。
upstream nacoscluster {
server 192.168.0.127:8841;
server 192.168.0.127:8842;
server 192.168.0.127:8841;
}
server {
listen 80;
server_name localhost;
#charset koi8-r;
#access_log logs/host.access.log main;
location /nacos/ {
#root html;
#index index.html index.htm;
proxy_pass http://nacoscluster/nacos/;
}
}
简单测试集群模式
1、访问192.168.0.17/nacos可以正常访问,前面说到的功能都可以正常使用。
2、Nacos集群模式需要至少两个存活实例节点,读者朋友可以通过关闭实例节点来测试验证。
关注公众号了解更多原创博文

感谢每一位关注的读者朋友,你们的关注是我继续写作与分享的动力!!!
Spring Cloud Alibaba 教程 | Nacos(六)的更多相关文章
- Spring Cloud Alibaba 教程 | Nacos(一)
什么是Nacos Nacos是一个更易于构建云原生应用的动态服务发现.配置管理和服务管理平台. Nacos 致力于帮助您发现.配置和管理微服务.Nacos提供了一组简单易用的特性集,帮助您快速实现动态 ...
- Spring Cloud Alibaba 教程 | Nacos(五)
扩展配置(extended configurations) 通过之前的学习,我们知道应用引入nacos配置中心之后默认将会加载Data ID= ${prefix} - ${spring.profile ...
- Spring Cloud Alibaba 教程 | Nacos(三)
使用Nacos作为配置中心 前面我们已经介绍过滤Nacos是一个更易于构建云原生应用的动态服务发现.配置管理和服务管理平台.所以它可以作为注册中心和配置中心,作为注册中心Nacos可以让我们灵活配置多 ...
- Spring Cloud Alibaba 教程 | Nacos(二)
源码解析客户端注册过程 nacos作为注册中心,包含了nacos服务端(注册中心服务)和nacos客户端,nacos注册中心服务上面一讲已经介绍过了它是一个用Java语言编写开源web项目,并且拥有自 ...
- Spring Cloud Alibaba 教程 | Nacos(四)
Nacos环境隔离 Nacos管理台有一个单独的菜单"命名空间",里面默认存在一个名为"public"的默认命名空间,我们在使用Nacos时不管是作为注册中心还 ...
- Spring Cloud Alibaba 使用nacos 注册中心
### 背景 上一文我们讲到了如何去搭建注册中心,这一次我们讲述如何使用nacos作为注册中心 ### spring-cloud-alibaba-basis 创建基础依赖 首先我们创建一个spring ...
- Spring Cloud Alibaba(6)---Nacos持久化Mysql8.0版本
Nacos持久化Mysql8.0版本 有关Nacos之前写过三篇文章. Spring Cloud Alibaba(3)---Nacos概述 Spring Cloud Alibaba(4)---Naco ...
- spring cloud系列教程第六篇-Eureka集群版
spring cloud系列教程第六篇-Eureka集群版 本文主要内容: 本文来源:本文由凯哥Java(kaigejava)发布在博客园博客的.转载请注明 1:Eureka执行步骤理解 2:集群原理 ...
- Spring Cloud Alibaba(2)---Nacos概述
Spring Cloud Alibaba(2)---nacos概述 上一篇博客讲了有关 SpringCloudAlibaba的概述,这篇开始讲SpringCloudAlibaba组件之一---Naco ...
随机推荐
- 安装npm install时,长时间停留在fetchMetadata: sill 解决方法——换npm的源
安装npm install时,长时间停留在fetchMetadata: sill mapToRegistry uri http://registry.npmjs.org/whatwg-fetch处, ...
- Oracle SQL 异常处理
今天学了异常处理 有预定义异常 与 用户自定义异常 还有 raise_application_error()函数raise_application_error() 只能把异常抛出而不能处理异常. 预定 ...
- Jrebel 远程热部署[Idea]
服务器端 客户端-idea remote module 在服务器端,Tomcat的webapps下新建项目文件夹,如: demo/WEB-INF/classes/[jrebel.xml]
- 超级简单 一分钟实现react-native屏幕适配
今天因为react-native的style只能给width和height设置数字 没有react上的vw和vh 因为之前经常用vh vw 感觉不适应 找到了一个新的方法 使用Demension模块 ...
- hdu 1251 统计难题 前缀出现次数
统计难题 Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 131070/65535 K (Java/Others)Total Submi ...
- Day 22:网络编程(3)
TCP通讯协议特点: 1. tcp是基于IO流进行数据 的传输的,面向连接. 2. tcp进行数据传输的时候是没有大小限制的. 3. tcp是面向连接,通过三次握手的机制保证数据的完整性.可靠协 ...
- weex框架
weex优势: (1)支持ES6规范 (2)性能优异,开发简介标准,提及小巧. (3)跨平台 weex调试工具:weexplayground weex环境搭建: (1)安装 node.js.npm ( ...
- POJ 3663:Costume Party
Costume Party Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 12607 Accepted: 4977 De ...
- 三十一、CI框架之使用验证码
一.CI的验证码功能用着很是舒服,需要在根目录下新建一个captcha的验证码文件夹用于存放生产的图片,代码如下: 二.浏览器效果如下: 总结:关于验证码生产函数,有很多参数可以设置,包括字体,验证码 ...
- 七、CI框架之分配变量数组,循环输出
一.添加并传递变量 二.在View界面输出 输出显示 不忘初心,如果您认为这篇文章有价值,认同作者的付出,可以微信二维码打赏任意金额给作者(微信号:382477247)哦,谢谢.