SpringCloud Alibaba——Nacos服务注册与配置中心(三Nacos持久化配置 & 集群搭建)

Posted 张起灵-小哥

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SpringCloud Alibaba——Nacos服务注册与配置中心(三Nacos持久化配置 & 集群搭建)相关的知识,希望对你有一定的参考价值。

1.开篇

前两篇文章分别说到了Nacos作为服务注册中心、服务配置中心的情况,现在我们来聊聊有关Nacos持久化配置以及Nacos的集群搭建。

官方文档:https://nacos.io/zh-cn/docs/cluster-mode-quick-start.html,最终搭建出来的Nacos集群应该是下图这样:👇👇👇

最前面是我们发出的请求,这个请求会被nginx挡下,来做反向代理、负载均衡,平摊到多台Nacos服务器中,最终连接上高可用的mysql集群。

默认Nacos使用嵌入式数据库实现数据的存储。所以,如果启动多个默认配置下的Nacos节点,数据存储是存在一致性问题的。为了解决这个问题,Nacos采用了集中式存储的方式来支持集群化部署,目前只支持MySQL的存储。


2.项目源码

github源码地址:https://github.com/2656307671/SpringCloud-Alibaba-Nacos

gitee源码地址:https://gitee.com/szh-forever-young/SpringCloud-Alibaba-Nacos

由于Nacos默认自带的是嵌入式数据库derby,在搭建集群的时候会出现数据一致性问题。所以这里要进行持久化配置,将Nacos中的默认数据库从derby切换到mysql。

首先,需要到github上下载nacos的linux版本,链接:https://github.com/alibaba/nacos/releases/tag/1.1.4,下载完成之后将压缩包上传至linux中,你可以使用Xftp,也可以使用 rz 命令。

我这里解压完成之后,将nacos目录下的内容进行了备份,备份到一个mynacos的目录下。避免出错之后没法恢复的情况。

Nacos下载安装完成之后,我们要进行持久化配置,将数据库从derby切换到mysql。

在nacos的目录下,有一个conf目录,conf目录下有一个sql脚本叫 nacos-mysql.sql,我们要做的就是执行这个sql脚本。

source命令执行完成之后,你可以show tables;查看有哪些表。这里我就没有再截图。

下一步找到 mynacos 目录下的conf,conf目录中有一个 application.properties 文件,也是避免出错,先将其拷贝一份,再进行修改。

修改的内容如下,就是将nacos中的数据库从derby切换到mysql,同时设置mysql的相关连接信息。

参考官方文档:https://nacos.io/zh-cn/docs/deployment.html

到此,nacos持久化配置就完成了。下面要做的就是nacos的集群环境搭建了。(预计是 1台Nginx + 3台Nacos + MySQL)

首先梳理出3台Nacos的端口号,这里分别设置为3333、4444、5555。这个Nacos的集群节点信息需要在conf目录下的cluster.conf.example中进行配置,还是老规矩,先将其备份,然后进行修改。

PS:这里的ip不能写127.0.0.1,因为这是在同一台linux系统中配置了3台nacos,写成127.0.0.1了话无法分清到底是哪一台nacos。

我们这里将集群节点信息添加完成,一会启动肯定是使用命令 startup.sh -p port ,那么nacos它如何知道你这个 -p 参数是什么意思呢?

这就需要到nacos中的bin目录下的startup.sh这个文件中进行修改。老规矩:修改之前先备份。

配置完上述内容之后,我们可以启动3台nacos服务器(3333、4444、5555)。

可以看到数量为3,就说明3台nacos服务器已经成功启动。

下面就要进行nginx的配置了,那必然要找到其配置文件:nginx.conf。

修改完成,下面启动nginx。

此时,我们的nginx启动完成、nacos启动完成、mysql后台正常运行。

这里一定要将防火墙关掉!!!这里一定要将防火墙关掉!!!这里一定要将防火墙关掉!!!

下面去浏览器中测试就行,因为我们上面配置了nginx的服务监听端口号为1111,而nginx在这里作为反向代理、负载均衡的角色,必然会挡下浏览器发出的请求,来为3台nacos服务器进行任务平摊,所以我们访问的url就应该是 虚拟机ip + nginx端口号 这样的形式。

你要是想直接3333、4444、5555肯定不行,因为在它们三个的前面挡着一个nginx呢。

账号密码都是nacos,点击提交,出现nacos的首页,则说明nacos集群、持久化配置已经全部完成。

这里,我再测试一下nacos作为服务配置中心的情况,首先新建一个配置文件,随便写点内容,保存。

然后回到mysql中,查询 config_info 这张表,可以看到我们刚刚添加的 nacos-config-client.yaml 文件。

最后再测试一下nacos作为服务注册中心的情况,因为之前是单机版的nacos,而现在要将9002注册进nacos集群,所以必须要修改9002的yml配置文件。然后再启动9002微服务模块(服务提供者)。9002的源码请参考上面给出的git仓库。

启动完成之后,到nacos的服务列表中查看,可以看到我们的9002(nacos-payment-provider)已经成功注册进了nacos集群。

以上,就是nacos的持久化配置、集群环境搭建的全部过程!!!

下面这张图是整个nacos集群的轮廓图。

以上是关于SpringCloud Alibaba——Nacos服务注册与配置中心(三Nacos持久化配置 & 集群搭建)的主要内容,如果未能解决你的问题,请参考以下文章

springcloud复习3

SpringCloud - Spring Cloud Alibaba 之 Nacos Config配置中心

springcloud+nacos+sentinel+dubbo搭建项目的一些关键配置和依赖

spring cloud 服务注册、发现了解

Nacos Config 配置中心攻略和详解

2021-11-22 spring-cloud-nacos配置优先级