vfp 删除临时表记录_第20问:删除了数据文件,该往哪个方向逃跑

博客围绕 MySQL 的 ibd 文件被删除后的恢复问题展开。先介绍建测试库、模拟业务压力并删除表文件的实验过程,接着阐述通过文件句柄复制恢复数据的方法,还解释了 Linux 删除文件原理及 procfs 查找文件句柄的作用,最后提出数据恢复时的思考题。
0253ec327bca5962092b624b80dc4634.png

问题

我写错了脚本,ibd 文件被删除了,该往哪个方向逃跑?

实验

先来建一个测试库:

92209801f2e37fcce0b6d9ea2ea962f9.png

我们在这里开启了 innodb_file_per_table,但这个参数并非本实验所必须,只是为了演示方便。

然后模拟一个业务压力:

6b82ac6f4d67591d49d319564abb1b4f.png

现在删掉相关的表文件:

9e655754cff895b1dd6d00e42a2115ac.png

可以打开地图 app,选择一个方向开始跑路了...

3dd042edfb1d8e45c3dcba0dd3c43f10.png

然而我们还可以挣扎一下,

查看一下 MySQL 占用的句柄:

e3577f70ad872c5597a0c1ceba5a1635.png

找到被删除的表:

3c7daf42a7ce1cc98ad9c21e2a2b4dda.png

可以看到,除了临时表,被我们手工删除的表也在其中,对应文件句柄号 54。

现在我们把数据库的流量锁起来(如果使用了支持 offline_mode 的版本,可以设置 offline_mode):

7621cbf7399e18bdf49ff692b9b63427.png

现在记录一下表的记录数和校验值,以便跟恢复后的数据比较:

8948dce9673bac5bc16244a5be53f0c8.png

现在通过文件句柄找到消失的数据文件,并将其复制出来(此处注意磁盘空间):

49cb9e5b65b73770fc73e129f570fd26.png

现在可以将数据库停下来,把恢复的数据复制到数据目录中,启动数据库:

d39341455ea6daa484801e6a7aa24583.png

看看数据是否正常:

c3942ce83e45d32f2d5588f703944915.png

看起来还不错。

实验原理

Linux 删除文件其实是减少了对文件的使用数,当使用数降为 0 时,才正式删除文件。

所以当我们执行 rm 时,由于 ibd 文件还在被 MySQL 使用,文件其实并没有被真实删除,只是没办法通过文件系统访问。

通过 procfs 查找文件句柄,可以让我们追踪到消失的文件。

思考题

即使我们停止了外部的数据压力,MySQL 也会自主做一些 buffer pool 的刷盘操作。

如果在我们复制数据文件的过程中,MySQL 触发了 buffer pool 的刷盘操作,那我们获得的数据文件不就不一致了么?是否会造成数据错误。


关于 MySQL 的技术内容,你们还有什么想知道的吗?赶紧留言告诉小编吧!

6df28d19d73d1d3fa5d0f4202eea9f25.png
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值