作者:晨星1032

一、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)查看是否成功

作者:晨星1032

参考

MySQL数据库迁移(数据文件直接迁移)-CSDN

MySQL直接拷贝数据库文件后出现table xxx doesn't exist解决方法-Penguin

Mysql,innodb使用.ibd文件快速批量恢复数据---批量快速-CSDN

MySQL数据库迁移与MySQL数据库批量恢复的更多相关文章

  1. mysql数据库迁移到oracle数据库后 如何删除相同的数据

    mysql数据库迁移到oracle数据库后 如何删除相同的数据 首先搞清楚有多少数据是重复的 select pid from product group by pid having count(pid ...

  2. [转载]如何将OFBIZ(opentaps)默认数据库迁移至mysql((2

    原文地址:如何将OFBIZ(opentaps)默认数据库迁移至mysql(利昂原创)作者:利昂 ofbiz自带的数据库是Derby,这是一种小型的适合与测试系统的数据库,但不适合在产品级系统中使用,所 ...

  3. Oracle 数据库迁移到MySQL (kettle,navicate,sql developer等工具

    Oracle 数据库迁移到MySQL (kettle,navicate,sql developer等工具 1 kettle --第一次使用kettle玩迁移,有什么不足之处和建议,请大家指正和建议. ...

  4. 从其他数据库迁移到MySQL及MySQL特点

    从其他数据库迁移到MySQL Oracle,SQL Server迁移到MySQL 一些变化 不再使用存储过程.视图.定时作业 表结构变更,如采用自增id做主键,以及其他语法变更 业务SQL改造,不使用 ...

  5. 将ACCESS数据库迁移到SQLSERVER数据库

    原文:将ACCESS数据库迁移到SQLSERVER数据库 将ACCESS数据库迁移到SQLSERVER数据库 ACCESS2000文件 用ACCESS2007打开,并迁移到SQLSERVER2005里 ...

  6. MYSQL数据库迁移到ORACLE数据库

    一.环境和需求1.环境 MySQL数据库服务器: OS version:Linux 5.3 for 64 bit mysql Server version: 5.0.45 Oracle数据库服务器: ...

  7. 将sqllite3数据库迁移到mysql

    一.安装python mysql module (OneDrive): 1.运行python D:\OneDrive\Work\django\mysqlregistry.py2.http://www. ...

  8. ubuntu系统lamp环境搭建、数据库迁移、设置数据库外部访问

    sudo passwd root设置两次密码su输入设置的密码exit (退出root帐号) 1.sudo apt-get update 2.sudo apt-get install apache2 ...

  9. [MySQL] SqlServer 迁移到 MySQL 方法介绍

    一.原则: 只迁移表结构和数据,存储过程.函数.触发器尽量自己改写,并充分测试. 迁移前,先设置好数据库的一些参数,比如默认存储引擎,默认编码等,方便后续导入. 二.方法: 1.使用MySQL Wor ...

随机推荐

  1. Java并发编程实战(5)- 线程生命周期

    在这篇文章中,我们来聊一下线程的生命周期. 目录 概述 操作系统中的线程生命周期 Java中的线程生命周期 Java线程状态转换 运行状态和阻塞状态之间的转换 运行状态和无时限等待状态的切换 运行状态 ...

  2. 【Python】用字母生成图像

    用字母生成图像会用到matplotlib.pyplot库 所以需要安装这个库 pip install matplotlib 等待安装完成即可 ps:由于网络原因,会出现多次的timeout,可以使用国 ...

  3. 【Nginx】配置nginx图片服务器

    想通过nginx来访问服务器上的图片 可以搭建一个nginx图片服务器. 做法如下: 先安装nginx,这里直接用yum来进行安装的 安装方法如下: https://blog.csdn.net/iml ...

  4. 【Linux】扩大swap分区

    今天安装oracle的时候,提示我swap分区过小.需要最少3g以上 但是安装系统了,想要扩大swap分区怎么办呢 下面来介绍如何扩大swap分区 按步骤介绍 Red Hat linux 如何增加sw ...

  5. 【linux】系统编程-7-网络编程

    目录 前言 10. 网络编程 10.1 简要网络知识 10.2 IP协议 10.2.1 IP地址编址 10.2.2 特殊IP地址 10.2.1 首限广播地址 10.2.2 直接广播地址 10.2.3 ...

  6. Spring Validation 验证

    基本配置 1.pom引入maven依赖 <dependency> <groupId>javax.validation</groupId> <artifactI ...

  7. 3A限流IC,带短路保护,PW1503和PW1502

    一般说明 PW1503,PW1502是超低RDS(ON)开关,具有可编程的电流限制,以保护电源源于过电流和短路保护.它具有超温保护以及反向闭锁功能. PW1503,PW1502采用薄型(1毫米)5针薄 ...

  8. 前端知识(二)08-Vue.js的路由-谷粒学院

    目录 一.锚点的概念 二.路由的作用 三.路由实例 1.复制js资源 2.创建 路由.html 3.引入js 4.编写html 5.编写js 一.锚点的概念 案例:百度百科 特点:单页Web应用,预先 ...

  9. 基于scrapy框架的分布式爬虫

    分布式 概念:可以使用多台电脑组件一个分布式机群,让其执行同一组程序,对同一组网络资源进行联合爬取. 原生的scrapy是无法实现分布式 调度器无法被共享 管道无法被共享 基于 scrapy+redi ...

  10. ajax异步实现文件分片上传

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...