服务器迁移MySQL

devtools/2025/1/19 4:09:43/

由于公司原有的服务器不再使用,需要将老的服务器上的MySQL迁移到新的服务器上,因此需要对数据进行备份迁移,前提是两台服务器已安装相同版本的MySQL,这里就不再讲解MySQL的安装步骤了,可以安装包、可以在线下载、可以容器部署等等,以下只做数据的备份迁移。

方式一:将原服务器的MySQL停掉,打包data,scp到新的服务器,在进行解压。这种方式是有风险的,需要考虑MySQL是否能够正常启停、项目上是否在用或者项目是否上线,如果项目已上线,这种方式是不可取的,如果是只有开发在用的话打过招呼应该是可以的。

方式二:使用MySQLdump的方式对全库、单库、指定表进行备份迁移

使用 ps -ef | grep mysql 可以找到MySQL的启动指令,也可以知道MySQL的部署路径,我们先切换路径到 bin 目录下,因为所有的可执行文件都是放在了bin目录下的

接下来我们就可以对全库、单库、指定表进行备份迁移了

全库:

/path/to/mysqldump  -h xxxx.xx.xx.xx -P端口   -u用户名 -p --all-databases>/path/to/all_databases.sql

在这里就成功的将服务器MySQL内的所有数据库进行了备份,全库8G

单库:

如果我们想要对单个库进行备份,那么只需要加一个参数就可以了:--databases

/path/to/mysqldump  -hxxxx.xx.xx.xx -P端口 --no-create-db  -utdxx -p --databases analyse_augment>/data/beifei/analyse_augment1.sql

这里边我又多加了一个   --no-create-db 参数,这个参数的目的输在生成 SQL 脚本的时候不生成 create database 语句,因为我们后续可能会将生成的脚本放到别的库,此外,在生成脚本的时候还会生成 use database 的语句,这里我们也是不需要的,如果我们直接使用 vi/vim 对SQL文件进行编辑,那么很不幸,大文件是很难搞的,我们可以使用 Linux 三剑客之一的 sed 进行处理:

sed -i 's/USE `analyse_augment`;/ /g' 文件名

 在这里我们将 USE `analyse_augment`; 替换成为了 空格,这对整个脚本是没有影响的,也正是我们想要的

指定表:

此外,我们还可以针对某个库中的指定表进行备份

/path/to/mysqldump  -hxxxx.xx.xx.xx -P端口 --no-create-db  -utdxx -p --databases 库名 表1 表2 > /data/beifei/tables_backup_202501151130.sql

 

备份完成之后,我们需要将生成的脚本 scp 到新的服务器

 scp -r ./beifei/ td_gyfx_01@132.252.204.30:/data/beifei/

 

OK,到这里基本已经完成了百分之九十了,最后要做的就是将SQL脚本内的数据搞到数据库里

全部数据库
/path/to/mysqldump  -hxxxx.xx.xx.xx -P端口  -u用户名 -p < all_databases.sql
单个数据库
/path/to/mysqldump  -hxxxx.xx.xx.xx -P端口  -u用户名 -p test < /data/beifei/analyse_augment1.sql

指定表

/path/to/mysqldump  -hxxxx.xx.xx.xx -P端口  -u用户名 -p test < /data/beifei/表.sql

 其实指定表和指定数据库的数据恢复是一致的,因为在生成SQL脚本的时候会生成

drop table if exist

至此,我们实现了数据的迁移工作,最后,我们可以去验证一下

服务器

服务器

 


http://www.ppmy.cn/devtools/151735.html

相关文章

如何构建优质的prompt

优化前&#xff1a; 帮我做一幅很好看的画&#xff0c;一只猫趴在透明的泡泡上&#xff0c;眼睛盯着前方看&#xff0c;泡泡上还打着光非常可爱&#xff0c;整体上是粉色系为主的动画风格 优化后&#xff1a; 画一幅画&#xff0c;呆萌的小猫躺在泡泡中&#xff0c;可爱温柔&am…

【新人系列】Python 入门(二十六):常见设计模式

✍ 个人博客&#xff1a;https://blog.csdn.net/Newin2020?typeblog &#x1f4dd; 专栏地址&#xff1a;https://blog.csdn.net/newin2020/category_12801353.html &#x1f4e3; 专栏定位&#xff1a;为 0 基础刚入门 Python 的小伙伴提供详细的讲解&#xff0c;也欢迎大佬们…

Java List过滤 Stream API filter() 应用

Java 8 前用 for-each 循环或 Iterator 处理集合&#xff0c;引入 Stream API 后可更简洁、声明式地处理集合&#xff0c;在复杂数据处理时更便捷 1. Stream与Filter基础 Stream 是从支持数据源获取数据的序列&#xff0c;有强大 API 可执行中间和最终操作&#xff0c;能内部…

RPC 简介

RPC&#xff08;Remote Procedure Call&#xff0c;远程过程调用&#xff09;是一种通过网络请求执行远程服务器上的代码的技术&#xff0c;使得开发者可以调用远程系统中的函数&#xff0c;就像调用本地函数一样。它隐藏了底层网络通信的细节&#xff0c;简化了分布式系统的开…

C++学习记录

本文章建立在已学C语言的基础上 第一阶段 生成随机数函数&#xff1a;rand()。rand()%100指的是生成0~99的随机数。这样生成的随机数每次都是一样顺序出现的&#xff0c;为了防止这个问题出现&#xff0c;我们可以使用随机数种子&#xff0c;如下代码 #include<iostream&…

使用 Golang 编译 Linux 可运行文件

Golang&#xff08;或 Go&#xff09;是一种开源编程语言&#xff0c;因其简单、高效、并发编程支持而备受欢迎。本文将详细介绍如何使用 Golang 编译生成可以在 Linux 上运行的可执行文件。 一、安装 Golang 1.1 下载 Golang 从 Golang 官方网站下载适合你操作系统的安装包…

【STM32-学习笔记-7-】USART串口通信

文章目录 USART串口通信Ⅰ、硬件电路Ⅱ、常见的电平标准Ⅲ、串口参数及时序Ⅳ、STM32的USART简介数据帧起始位侦测数据采样波特率发生器 Ⅴ、USART函数介绍Ⅵ、USART_InitTypeDef结构体参数1、USART_BaudRate2、USART_WordLength3、USART_StopBits4、USART_Parity5、USART_Mode…

多态(4)

大家好&#xff0c;今天我们来讲讲向下转型这个知识点&#xff0c;这个知识点并没有向上转型用得那么频繁&#xff0c;但是也需要了解一下。 2.4.2向下转型 当一个子类对象经过向上转型之后当成父类方法使用,再无法调用子类的属性和方法。但有时候可能需要调用子类的属性和方…