MariaDB通过物理文件进行数据恢复

域名2025-11-05 08:35:0881639

1、过物起因

时间:2022.03.12 10:10。理文

事件:网站的进据恢 mariadb 数据库 server 突然崩溃,尝试各种办法启动无果。行数

过程:不幸的过物是数据库没有备份,万幸的理文是可以通过数据库物理文件恢复数据。

结果:恢复数据,进据恢并特此记录整个过程,行数以备急时之需。过物

2、理文数据库与数据文件

众所周知,进据恢数据库中的行数数据会以文件的形式落盘进行保存(这些文件是以某种特定格式存储的,不是过物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 存储数据的根目录)。

3、 ibdata 作用

ibdata (是InnoDB基础结构的系统表空间) 包含几个对InnoDB至关重要的信息:

表格数据页。表索引页。数据字典。MVCC控制数据。撤消空间、回滚段双重写入缓冲区(在后台写页面以避免操作系统缓存)。插入缓冲区(对二级索引的更改)。香港云服务器

笔者这里 innodb_file_per_table=0,使用共享表空间 ibdata1,所以恢复数据时需要拷贝这个文件 关于这个文件具体可以查阅相关资料。

对于笔者来说,虽然 数据库 server 挂了,但是这些关键性的文件还是完整的。那么,就有办法通过这些文件来恢复对应的数据。

举个不太恰当的例子:

这里的数据恢复有点像器官移植,器官捐献者可能已经大脑死亡。

但是捐献者的心脏等器官还是有活力的,找到适合的目标受体,这些器官还是能够继续工作的。

4、 恢复过程

这里以 ivansli database 数据库的恢复为例,整个恢复过程大致如下:

(1)查看当前待恢复的数据所在的 server(这里称为 源数据库server) 类型以及版本 笔者这里使用的服务器租用是 mariadb - 10.7.0。

为什么要看已经 crash 掉的数据库 server 的类型、版本呢?

主要是为数据恢复找到一个匹配的环境(类比器官移植,也是需要找到相同、相近的匹配受体,否则就会出问题)。

(2)在其他服务器搭建 与 源数据库server 相同或者相近版本的 数据库server (这里称为 目标数据库server) 搭建好之后,先把 目标数据库server 停掉,暂时不启动,为后面拷贝数据做准备。

(3)把 源数据库server 待恢复的文件夹(这里是 ivansli 文件夹)与 ibdata1 文件拷贝到 目标数据库server 数据目录下 ivansli 文件夹在 目标数据库server 数据库存储数据目录下不存在,直接拷贝。ibdata1 文件在 目标数据库server 数据库存储数据目录下有同名文件,直接覆盖。

(4)修改 目标数据库server 数据库存储数据目录下相关文件权限。

chmod -R 660 ivansli ibdata1

chown -R mysql:mysql ivansli ibdata1

chmod +x ivansli

(5)启动 目标数据库server。

(6)使用 root 账号登录 目标数据库server,查看数据恢复情况。

(7)目标数据库server上 能够看到待恢复数据,做数据备份导出保存。

(8)在 源数据库server 服务器上搭建新的 数据库server,把恢复的数据导入进来。

5、 总结

对于开发人员来说,会经常听到删库跑路、删库坐牢之类的事情发生。对于公司来说,最重要的是用户的数据信息,尤其是金融等行业,宁可服务不可用,数据安全是一定要保证的。

这篇文章所描述的是在数据文件存在的特定情况下进行简单的数据恢复。对于数据文件被删除掉的情况,可能要进行扫描磁盘等更专业的操作了。

总之一句话:善待每一行代码,谨慎敲打每一个命令。还有就是:做好数据备份、做好数据备份、做好数据备份。

本文地址:http://www.bzuk.cn/news/316f39299291.html
版权声明

本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。

全站热门

探索LGUF6800电视的功能与特点(一款高性能的智能电视体验)

从磁盘格式到转化(解密磁盘格式转化步骤,助您管理数据存储)

华硕K456UJ6200笔记本电脑的性能和特点(华硕K456UJ6200笔记本电脑值得购买的原因及用户体验)

iOS10.3Beta4的新特性与改进(提高性能和用户体验的关键更新)

内存错误的解决方法(电脑提示发生内存错误,如何应对?)

手动运行盘重装系统教程(学会手动运行盘重装系统,让你的电脑焕然一新)

通过DNS地址设置实现上网的方法(利用DNS地址设置畅游互联网,让网络连接更畅快快速)

JVCGZ-HM400(卓越画质、强大功能与出色性能的完美结合)

友情链接

滇ICP备2023006006号-33