Nacos持久化Mysql8.0版本

有关Nacos之前写过三篇文章。

Spring Cloud Alibaba(3)---Nacos概述

Spring Cloud Alibaba(4)---Nacos(注册中心)

Spring Cloud Alibaba(5)---Nacos(配置中心)

一、背景

我们服务的信息、配置的信息都放在哪的?官网有说过

当我们使用默认配置启动Nacos时,所有配置文件都被Nacos保存在了内置的数据库中。

这里所指的内置数据库其实就是内存中,既然是配置在内存中,那么每当我们重启Nacos的时候,所有配置好的信息都会丢失,这显然是我们不能够接受的,所以我们就需要去配置,

让配置数据存在Mysql中,这样当我们重启服务器的时候,配置数据依旧在。

架构信息

Nacos 1.4.2 + MYSQL 8.0.22

二、Nacos客户端部署

客户端部署其实官方给了两种方式 一种是 从 Github 上下载源码。另一种是 直接下载压缩包官方地址

之前在写Nacos概述的时候,是直接去官网下载 nacos-server-1.3.2.tar.gz 的压缩包,下载解压后 通过命令运行。这里我们需要用第二种方式,我们直接去拉nacos源码后,

自己打成nacos-server-1.4.2-SNAPSHOT.tar.gz 压缩包。

为什么要不用官方直接提供的压缩包,而需要我们自己下源码在打成压缩包,这样多次一举呢?

是因为,我们是 MYSQL 8.0.22 版本的,所以我们要下载源码,把pom文件中对应的连接数据库的驱动jar包改成8.0.22版本的,然后重新打成压缩包。

1、拉取源码

这个当前拉取的是1.4.2版本的Nacos,你也可以指定拉取版本

git clone https://github.com/alibaba/nacos.git

2、修改Mysql连接驱动

1.4.2版本的Nacos所用的mysql-connector-java版本是8.0.21,这里修改成 8.0.22。

<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.22</version>
</dependency>

注意 其实这里可以不用修改,因为8.0.21和8.0.22,差异很小,所以我们不用修改都是可以的。就是说我们都不用取拉源码在通过命令打包,而是直接下载1.4.2版本的

压缩包就可以了。当然如果你的是1.3.1以下版本的Nacos,那么Mysql驱动是5.7版本的那么这个是需要修改成8以上版本的。

3、打包

进入nacos目录

cd nacos

maven打包

mvn -Prelease-nacos -Dmaven.test.skip=true clean install -U

如果直接成功后,在distribution/target/目录中就已经有相应的解压包了。

4、解压

tar -xvf nacos-server-1.4.2-SNAPSHOT.tar.gz

接下来我们先不启动服务器,因为我们还需要修改一些配置文件

三、修改配置文件

1、初始化数据库

Nacos的数据库脚本文件在我们下载Nacos-server时的压缩包中就有

进入nacos\conf目录,初始化文件:nacos-mysql.sql

此处我创建一个名为 nacos 的数据库,然后执行初始化脚本,成功后会生成 12 张表

2、修改配置文件

它的配置文件也在 nacos\conf目录下,名为 application.properties,在文件底部添加数据源配置:

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

3、启动服务器

现在数据库和配置都已经修改了,那么就启动服务器

//先进入bin目录
cd nacos/bin

启动命令(standalone代表着单机模式运行,非集群模式):

sh startup.sh -m standalone

如果您使用的是ubuntu系统,或者运行脚本报错提示[[符号找不到,可尝试如下运行:

bash startup.sh -m standalone

注意 执行命令地方在上面压缩的 distribution/target/nacos-server-1.4.2-SNAPSHOT/nacos/bin 位置下,而不是在distribution的bin下。

启动后,能够正常访问下面地址,那就说明已经配置成功,

http://127.0.0.1:8848/nacos

如果上面访问失败,那就去 nacos\log 目录下,名为 nacos.log 看下有没有错误日志

四 测试

1、在客户端新添加一条配置数据

看列表 也显示这条配置集已经创建成功

2、查看数据库

既然客户端都生成成功了,那就来看下数据库中有没有持久化这条数据

很明显 数据中也有这条数据,这样就算nacos重新启动这条数据也还是会有了。

参考

1、nacos官网快速启动

2、nacos数据持久化MySQL8.0以上版本

3、Spring Cloud Alibaba基础教程:Nacos的数据持久化

少说多做,句句都会得到别人的重视;多说少做,句句都会受到别人的忽视。(6)

Spring Cloud Alibaba(6)---Nacos持久化Mysql8.0版本的更多相关文章

  1. Spring Cloud Alibaba(2)---Nacos概述

    Spring Cloud Alibaba(2)---nacos概述 上一篇博客讲了有关 SpringCloudAlibaba的概述,这篇开始讲SpringCloudAlibaba组件之一---Naco ...

  2. Spring Cloud Alibaba(4)---Nacos(注册中心)

    Nacos(注册中心) 有关Spring Cloud Alibaba之前写过三篇文章. Spring Cloud Alibaba(1)---入门篇 Spring Cloud Alibaba(2)--- ...

  3. Spring Cloud Alibaba(5)---Nacos(配置中心)

    Nacos(配置中心) 有关Spring Cloud Alibaba之前写过四篇文章,这篇也是在上面项目的基础上进行开发. Spring Cloud Alibaba(1)---入门篇 Spring C ...

  4. Spring Cloud Alibaba(3)---Nacos概述

    Spring Cloud Alibaba(3)---nacos概述 上一篇博客讲了有关 SpringCloudAlibaba的概述,这篇开始讲SpringCloudAlibaba组件之一---Naco ...

  5. Spring Cloud Alibaba 之 Nacos

    Nacos 技术讲解 一提到分布式系统就不的不提一下 CAP 原则 什么是CAP CAP原则又称CAP定理,指的是在一个分布式系统中,一致性(Consistency).可用性(Availability ...

  6. Spring Cloud Alibaba 使用nacos 注册中心

    ### 背景 上一文我们讲到了如何去搭建注册中心,这一次我们讲述如何使用nacos作为注册中心 ### spring-cloud-alibaba-basis 创建基础依赖 首先我们创建一个spring ...

  7. Spring Cloud Alibaba 教程 | Nacos(一)

    什么是Nacos Nacos是一个更易于构建云原生应用的动态服务发现.配置管理和服务管理平台. Nacos 致力于帮助您发现.配置和管理微服务.Nacos提供了一组简单易用的特性集,帮助您快速实现动态 ...

  8. Spring Cloud Alibaba 整合 Nacos 实现服务配置中心

    在之前的文章 <Nacos 本地单机版部署步骤和使用> 中,大家应该了解了 Nacos 是什么?其中 Nacos 提供了动态配置服务功能 一.Nacos 动态配置服务是什么? 官方是这么说 ...

  9. Spring Cloud Alibaba 之Nacos

    Nacos 技术讲解 一提到分布式系统就不的不提一下 CAP 原则 什么是CAP CAP原则又称CAP定理,指的是在一个分布式系统中,一致性(Consistency).可用性(Availability ...

随机推荐

  1. 微信小程序:数组拼接

    一开始用concat进行拼接,总是不行,代码如下: handleItemChange(e){ console.log(e) var itemList = e.detail.value itemList ...

  2. sql if else 用法

    语法: case when 条件1 then 结果1 when 条件2 then 结果2 else 结果N end 可以有任意多个条件,如果没有默认的结果,最后的else也可以不写, select c ...

  3. Pyqt5——带图标的表格(Model/View)

    需求:表格中第一列内容为学生学号,为了突出学号的表示,在第一列的学号旁增加学号图标. 实现:(1)使用Qt的model-view模式生成表格视图. (2)重写代理(QAbstractItemDeleg ...

  4. webpack + vuecli多页面打包基于(vue-template-admin)修改

    转: webpack + vuecli多页面打包基于(vue-template-admin)修改 遇见的问题TypeError: Cannot read property 'tap' of undef ...

  5. 《C++ Primer》笔记 第11章 关联容器

    关联容器类型 解释 按关键字有序保存元素 -- map 关联数组:保存关键字-值对 set 关键字即值,即只保存关键字的容器 multimap 关键字可重复出现的map multiset 关键字可重复 ...

  6. pytorch(15)损失函数

    损失函数 1. 损失函数概念 损失函数:衡量模型输出与真实标签的差异 \[损失函数(Loss Function): Loss = f(\hat y,y) \] \[代价函数(Cost Function ...

  7. Java数据类型拓展

    public class Demo03 { public static void main(String[] args) { //整数拓展: 二进制0b 十进制 八进制0 十六进制0x int i = ...

  8. Java I/O流 01

    文件IO·异常 和 File类 异常的概述和分类 * A:异常的概述 * 异常就是Java程序在运行过程中出现的错误 * B:异常的分类 * 用过API查看Throwable * Error * 服务 ...

  9. 如何在 ASP.NET Core 中写出更干净的 Controller

    你可以遵循一些最佳实践来写出更干净的 Controller,一般我们称这种方法写出来的 Controller 为瘦Controller,瘦 Controller 的好处在于拥有更少的代码,更加单一的职 ...

  10. dom_bom学习

    1. bom是什么? browser object model(浏览器对象模型) 在浏览器中 window指的就是bom对象 //网页重定向 // window.location.href=" ...