博客
关于我
重装Ubuntu系统后Mysql 数据恢复历程
阅读量:778 次
发布时间:2019-03-25

本文共 902 字,大约阅读时间需要 3 分钟。

安装了新的Ubuntu 16.04-server系统后,我发现服务器的部分数据丢失了,幸运的是硬盘未被格式化,至少保留了恢复MySQL数据的希望。默认的MySQL数据库目录位于**/var/lib/mysql**。

在尝试恢复数据的过程中,我需要先停止MySQL服务并挂载旧硬盘到本地电脑上。已知数据库目录下的文件位于**/media/user/f101a309-d55a-4a50-8e1c-d63534146b6f**。通过查看目录结构,确认了包含factoryTest数据库的相关文件和配置。

在初步尝试中,我将发现的数据库文件直接复制到服务器对应的MySQL目录下,并调整文件权限后,尝试重新启动数据库。但这次尝试并未成功,数据读取仍然失败,这让我意识到我需要采取更系统的方法来恢复数据。

通过进一步的搜寻和参考,了解到使用mysqlfrm工具可以帮助恢复表结构。我尝试在系统上安装了mysql-utilities软件包,并执行了以下命令:

mysqlfrm --diagnostic FactoryTest/Wifi.frm

这允许我从**.frm文件中提取表结构信息。创建了表的基本语句后,我可以手动复制这些语句并执行,成功创建了FactoryTest中的Wifi**表格。

接下来,为了恢复具体的数据,我使用了以下命令:

ALTER TABLE FactoryTest.Wifi DISCARD TABLESPACE;

这条命令帮助我释放了表的表空间占用空间。然后,我直接复制包含实际数据的**.idb**文件:

sudo cp -rn . /var/lib/mysql/FactoryTest/

完成复制后,我确保了文件权限:

sudo chown mysql:mysql -R /var/lib/mysql/FactoryTest

最后,在重新启动MySQL服务后,我通过执行以下命令为表格恢复数据空间:

ALTER TABLE FactoryTest.Wifi IMPORT TABLESPACE;

通过以上步骤,.db文件被成功复制并恢复了数据库中的数据,最终达成了恢复任务的目标。

转载地址:http://eavuk.baihongyu.com/

你可能感兴趣的文章
mysql查询数据库储存数据的占用容量大小
查看>>
MySQL查询数据库所有表名及其注释
查看>>
MySQL查询数据表中数据记录(包括多表查询)
查看>>
MySQL查询结果排序
查看>>
MYSQL查询语句优化
查看>>
mysql查询语句能否让一个字段不显示出来_天天写order by,你知道Mysql底层执行原理吗?
查看>>
MySQL查询语句:揭秘专家秘籍,让你秒变数据库达人!
查看>>
mysql查询超时对PHP执行的影响
查看>>
mysql查询输出到excel文件_如何保存mysql查询输出到excel或.txt文件?
查看>>
mysql查询过程
查看>>
Mysql模糊查询like效率,以及更高效的写法
查看>>
MySQL死锁套路:一次诡异的批量插入死锁问题分析
查看>>
Mysql死锁问题Deadlock found when trying to get lock;try restarting transaction
查看>>
mysql每个数据库的最大连接数_MySQL数据库最大连接数
查看>>
Mysql流程控制结构,if函数、case结构、if结构、循环结构
查看>>
mysql添加外网访问权限
查看>>
mysql添加用户
查看>>
MySQL添加用户、删除用户与授权
查看>>
mysql添加用户及权限
查看>>
Mysql添加用户并授予只能查询权限
查看>>