共计 2191 个字符,预计需要花费 6 分钟才能阅读完成。
导读 | 这篇文章所描述的是在数据文件存在的特定情况下进行简单的数据恢复。对于数据文件被删除掉的情况,可能要进行扫描磁盘等更专业的操作了。 |
时间:2022.03.12 10:10。
事件:网站的 mariadb 数据库 server 突然崩溃,尝试各种办法启动无果。
过程:不幸的是数据库没有备份,万幸的是可以通过数据库物理文件恢复数据。
结果:恢复数据,并特此记录整个过程,以备急时之需。
众所周知,数据库中的数据会以文件的形式落盘进行保存(这些文件是以某种特定格式存储的,不是 text 格式,试图用文本编辑器打开会看到乱码)。在数据库中,每一个 database 都是一个单独的文件夹,文件夹下存储着每一张表的相关文件(不同的存储引擎生成的表文件可能不同,这里使用 innodb 引擎)。
例如,笔者网站数据库名称叫做 ivansli,有一个用户表 – user,脱敏之后的数据文件布局大致如下:
➜ /usr/local/data tree -L 2
.
├── aria_log.00000001
├── aria_log_control
├── ib_buffer_pool
├── ibdata1
├── ib_logfile0
├── ibtmp1
├── iZuf63yp8w5ku4znrskda8Z.err
├── iZuf63yp8w5ku4znrskda8Z.pid
├── multi-master.info
├── mysql-bin.000001
├── mysql-bin.000002
├── mysql-bin.000003
├── mysql-bin.index
├── mysql-slow.log
├── performance_schema
│ └── db.opt
└── ivansli
├── db.opt
├── user.frm
├── user.MYD
└── user.MYI
这里的 /usr/local/data 数据库存储数据的目录。
ivansli 文件夹下可以看到有三个不同格式,相同名称的文件,作用分别为:user.frm,存储数据表的元数据 user.MYD,存储数据表的具体数据 user.MYI,存储数据表的索引。
除了每张表的若干个文件之外,对于数据库 server 来说还有一个重要的 ibdata1 文件(位于数据库 server 存储数据的根目录)。
ibdata (是 InnoDB 基础结构的系统表空间) 包含几个对 InnoDB 至关重要的信息:
笔者这里 innodb_file_per_table=0,使用共享表空间 ibdata1,所以恢复数据时需要拷贝这个文件 关于这个文件具体可以查阅相关资料。
对于笔者来说,虽然 数据库 server 挂了,但是这些关键性的文件还是完整的。那么,就有办法通过这些文件来恢复对应的数据。
举个不太恰当的例子:
这里的数据恢复有点像器官移植,器官捐献者可能已经大脑死亡。
但是捐献者的心脏等器官还是有活力的,找到适合的目标受体,这些器官还是能够继续工作的。
这里以 ivansli database 数据库的恢复为例,整个恢复过程大致如下:
为什么要看已经 crash 掉的数据库 server 的类型、版本呢?
主要是为数据恢复找到一个匹配的环境(类比器官移植,也是需要找到相同、相近的匹配受体,否则就会出问题)。
chmod -R 660 ivansli ibdata1
chown -R mysql:mysql ivansli ibdata1
chmod +x ivansli
对于开发人员来说,会经常听到删库跑路、删库坐牢之类的事情发生。对于公司来说,最重要的是用户的数据信息,尤其是金融等行业,宁可服务不可用,数据安全是一定要保证的。
这篇文章所描述的是在数据文件存在的特定情况下进行简单的数据恢复。对于数据文件被删除掉的情况,可能要进行扫描磁盘等更专业的操作了。
总之一句话:善待每一行代码,谨慎敲打每一个命令。还有就是:做好数据备份、做好数据备份、做好数据备份。