MySQL数据库迁移与MySQL数据库批量恢复
一、MySQL数据库迁移或备份
将相关数据库数据文件直接迁移方式
1. 了解使用InnoDB
引擎创建数据库所产生的文件
使用MySQL InnoDB
引擎所产生的文件(三个文件都很重要)
.ibd
:包含每个table的数据和索引.frm
:描述table的结构等ibdata1
:包含所有table的字典和历史操作
在data
文件夹下,每个数据库分别是一个文件夹(如:mosquitto
),ibdata1
文件会记录MySQL中所有InnoDB
数据库中table
的字典和历史操作:
在mosquitto
文件夹总,包含每个table
的.ibd
文件和.frm
文件
2. 迁移数据库步骤
基本要求:
- 保证MySQL版本基本一致,安装配置基本一致
- 停止两边的MySQL服务
1. 从A服务器迁移至B服务器
- 清空B服务器MySQL的data目录下所有文件
- 拷贝A服务器MySQL的data目录下除了ib_logfile和.err之外的文件到B服务器data下
- 启动B服务器的MySQL服务,检测是否发生异常
2. MySQL重装并导入之前数据库
- 备份MySQL的data目录下除了ib_logfile和.err之外的所有文件到其他目录
- 清空MySQL的data目录下所有文件
- 拷贝备份的数据文件到data目录下
- 启动MySQL服务,检测是否发生异常
注意:
迁移时将每个数据库文件夹时一定不能忘记ibdata1
文件,若不小心删除ibdata1
文件可以继续看以下内容恢复。
二、MySQL数据库批量恢复(通过.frm
和.ibd
文件批量恢复)
若不小心删除ibdata1
文件,即目前只有.frm
和.ibd
文件如何恢复数据?同时数据库表格过多又如何批量恢复?
1. 通过.frm
文件批量恢复表结构信息(使用mysqlfrm)
mysqlfrm其他版本(windows等)下载地址:https://downloads.mysql.com/archives/utilities/
(1)mysqlfrm安装
下载
wget https://cdn.mysql.com/archives/mysql-utilities/mysql-utilities-1.6.5.tar.gz
解压
tar -xvf mysql-utilities-1.6.5.tar.gz
cd mysql-utilities-1.6.5/
安装(需要Python环境,python2.6及以上)
python ./setup.py build
python ./setup.py install
检查是否安装成功
mysqlfrm --version
(2)使用mysqlfrm查看表结构创建语句
mysqlfrm有
--basedir
模式以及--server
模式,但推荐--server
,能够还原最为准确的信息
- 使用方式(启动MySQL服务)
格式:mysqlfrm --server=用户名:密码@数据库地址:端口 需恢复的frm文件目录 --diagnostic > 保存SQL文件名.sql
mysqlfrm --server=root:123456@192.168.11.130:3306 /mnt/mysql/mysql_data/mosquitto/*.frm --diagnostic > mosquitto_frm.sql
过程如图所示:
- 执行所生成的SQL文件
注:mysqlfrm仅显示整个数据库的表结构创建语句,可以显示在控制台也可以输出到文件,不过仍需要手动执行这些表创建SQL语句。
先创建数据库
CREATE DATABASE `mosquitto`
可以查看生成的sql文件手动删除相关无用信息等,可命令行执行或者客户端执行等
命令行
mysql -uroot -p123456 mosquitto < mosquitto_frm.sql
2. 通过.ibd
文件批量恢复表数据信息
(1)让表结构和表空间脱离
注:
若使用不了mysql命令或者执行mysql出现Can't connect to local MySQL server through socket '/tmp/mysql.sock'等问题时,请查看这一篇文章解决https://www.cnblogs.com/maogen/p/14353778.html
生成
mysql -uroot -p123456 -e " SELECT concat('alter table ', table_name, ' discard tablespace;') FROM information_schema.tables WHERE table_schema = 'mosquitto';" > tem_discard.sql
删除多余信息
sed '/^c/d' tem_discard.sql > discard.sql
执行命令
mysql -uroot -p123456 mosquitto < discard.sql
(2)将需要恢复的.ibd
替换到相关目录下
cp /mnt/mysql/mosquitto/*.ibd /mnt/mysql/mysql_data/mosquitto/
(3)权限设置
chown -R mysql.mysql /mnt/mysql/*
(4)导入表空间
生成
mysql -uroot -p123456 -e " SELECT concat('alter table ', table_name, ' import tablespace;') FROM information_schema.tables WHERE table_schema = 'mosquitto1';" > tem_import.sql
删除多余信息
sed '/^c/d' tem_import.sql > import.sql
执行命令
mysql -uroot -p123456 mosquitto < import.sql
(5)查看是否成功
参考
MySQL数据库迁移与MySQL数据库批量恢复的更多相关文章
- mysql数据库迁移到oracle数据库后 如何删除相同的数据
mysql数据库迁移到oracle数据库后 如何删除相同的数据 首先搞清楚有多少数据是重复的 select pid from product group by pid having count(pid ...
- [转载]如何将OFBIZ(opentaps)默认数据库迁移至mysql((2
原文地址:如何将OFBIZ(opentaps)默认数据库迁移至mysql(利昂原创)作者:利昂 ofbiz自带的数据库是Derby,这是一种小型的适合与测试系统的数据库,但不适合在产品级系统中使用,所 ...
- Oracle 数据库迁移到MySQL (kettle,navicate,sql developer等工具
Oracle 数据库迁移到MySQL (kettle,navicate,sql developer等工具 1 kettle --第一次使用kettle玩迁移,有什么不足之处和建议,请大家指正和建议. ...
- 从其他数据库迁移到MySQL及MySQL特点
从其他数据库迁移到MySQL Oracle,SQL Server迁移到MySQL 一些变化 不再使用存储过程.视图.定时作业 表结构变更,如采用自增id做主键,以及其他语法变更 业务SQL改造,不使用 ...
- 将ACCESS数据库迁移到SQLSERVER数据库
原文:将ACCESS数据库迁移到SQLSERVER数据库 将ACCESS数据库迁移到SQLSERVER数据库 ACCESS2000文件 用ACCESS2007打开,并迁移到SQLSERVER2005里 ...
- MYSQL数据库迁移到ORACLE数据库
一.环境和需求1.环境 MySQL数据库服务器: OS version:Linux 5.3 for 64 bit mysql Server version: 5.0.45 Oracle数据库服务器: ...
- 将sqllite3数据库迁移到mysql
一.安装python mysql module (OneDrive): 1.运行python D:\OneDrive\Work\django\mysqlregistry.py2.http://www. ...
- ubuntu系统lamp环境搭建、数据库迁移、设置数据库外部访问
sudo passwd root设置两次密码su输入设置的密码exit (退出root帐号) 1.sudo apt-get update 2.sudo apt-get install apache2 ...
- [MySQL] SqlServer 迁移到 MySQL 方法介绍
一.原则: 只迁移表结构和数据,存储过程.函数.触发器尽量自己改写,并充分测试. 迁移前,先设置好数据库的一些参数,比如默认存储引擎,默认编码等,方便后续导入. 二.方法: 1.使用MySQL Wor ...
随机推荐
- 如何在Linux(CentOS7)环境搭建 Jenkins 服务器环境
最近,我自己要亲手搭建一套完整的企业级 CI/CD 环境,这个环节里面涉及了很多内容,没有办法把这么多的内容都放在一篇文章里,所以 Jenkins 的安装和Java 的 JDK 安装我就是分了两篇文章 ...
- 机器学习之shape
shape[:2] 取彩色图片的长和宽 shape[:3]取彩色图片的长和宽和通道 img.shape[0]:图像的垂直高度 img.shape[1]:图像的水平宽度 img.shape[2]:图像的 ...
- kafka 异步双活方案 mirror maker2 深度解析
mirror maker2背景 通常情况下,我们都是使用一套kafka集群处理业务.但有些情况需要使用另一套kafka集群来进行数据同步和备份.在kafka早先版本的时候,kafka针对这种场景就有推 ...
- 这么优雅的Java ORM没见过吧!
Java的ORM框架有很多,但由于Java语言的限制大部分都不够优雅也不够简单,所以作者只能另辟蹊径造轮子了.照旧先看示例代码了解个大概,然后再解释实现原理. 一.ORM示例 1. Insert ...
- 洛谷P3275 [SCOI2011]糖果(差分约束)
题目描述 幼儿园里有 $N$ 个小朋友,$lxhgww $老师现在想要给这些小朋友们分配糖果,要求每个小朋友都要分到糖果.但是小朋友们也有嫉妒心,总是会提出一些要求,比如小明不希望小红分到的糖果比他的 ...
- typora+PicGo+gitee搭建免费的的床
一.gitee 1.第一步拥有自己的gitee账号 没有的可以自己去注册gitee地址 2.使用自己的gitee账号创建仓库 创建好之后注意 记住.com/以后的地址 此处就为y***L/photo- ...
- Markdown特殊字符、数学公式汇总
引自:https://blog.csdn.net/weixin_39653948/article/details/104621249
- 目标检测的评价指标(TP、TN、FP、FN、Precision、Recall、IoU、mIoU、AP、mAP)
1. TP TN FP FN GroundTruth 预测结果 TP(True Positives): 真的正样本 = [正样本 被正确分为 正样本] TN(True Negatives): 真的 ...
- requests模块的基本使用
requests模块的基本使用 基于网络请求的模块. 环境的安装:pip install requests 作用:模拟浏览器发起请求 分析requests的编码流程: 1.指定url 2.发起了请求 ...
- 【JeecgBoot】关于 jeecg-boot 的项目理解、使用心得和改进建议
工欲善其事,必先利其器. 脚手架选型 一年前,我接到为团队落地一个快速开发脚手架的任务. 在月底这节骨眼上,时间紧,任务急,有想自己撸一个脚手架的人都赶紧把这想法收起来吧!这劳民又伤身的事咱肯定是不能 ...