行句柄引用了一个已被删除 7346_第20问:删除了数据文件, 该往哪个方向逃跑

f99e350f6ece3eaf8e6005a5cdd7043d.png

问题

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

实验

先来建一个测试库:

4a78e549d69f8a651a387fb168836dfd.png

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

然后模拟一个业务压力:

6993e5849527c7ec6ade13300ef82cbe.png

现在删掉相关的表文件:

73109723830df214916681a33b08f27c.png

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

3b38d127821c466d0930f3ab75c6e1c5.png

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

查看一下 MySQL 占用的句柄:

401289329b14e804c3bbfe6333813606.png

找到被删除的表:

482b14593822ebe0d1989ac55ea4907a.png

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

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

6714ad4f0a76a0671d4109821aed0ad4.png

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

5f9cca2b3a24ccff211fdb210661e280.png

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

b4b34b1cd62644b2389fa3fd5b0660fa.png

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

91d3c2d189e2822b0fbe8950c865fb6c.png

看看数据是否正常:

4b68a958b9774a9305d6b2b874976aac.png

看起来还不错。

实验原理

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

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

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

思考题

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

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

关于爱可生

上海爱可生信息技术股份有限公司是国内开源数据库解决方案领导者、工业互联网高维数据应用创新者。爱可生为产业互联网创新应用提供高性价比、快速落地实现的多数据库管理平台、分布式数据库系统、数据库容器云平台、多地多中心跨云容灾等解决方案。

在工业互联网相关垂直行业,深入分析数据价值,构建数据中台和业务中台的基础软件PaaS平台,用数据技术驱动企业高质量增长。公司产品已被广泛应用于各行业,累计用户超过400家,其中包括工商银行、中国人寿、中国太保、国家电网、上汽集团、中国移动、华为等30多家世界500强企业。

c8839f645b9bbd35692b40d4512e02cb.png

57c0f55f954e8bdbffa5a83908d7974d.png

点击此处“阅读全文”,了解更多 d6ac3b17cdf3b5ea7ee3cd18f970d6eb.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值