在日常数据库运维中,数据意外丢失是令人头疼的问题。然而,mysql的二进制日志(binary log)就像一个“时光机器”,记录着数据库的所有变更,使我们能够将数据库恢复到任意时间点。本文将通过一个实际案例,详细介绍如何利用二进制日志进行数据恢复。
启用二进制日志文件
要使用二进制日志功能,首先需要在MySQL配置文件中启用它:
# 1. 修改MySQL配置文件vim /etc/my.cnf在[mysqld]部分添加以下内容
[mysqld]log-bin=/usr/local/mysql/data/mysql-binserver-id=1binlog_format=MIXED
2. 重启MySQL服务
systemctl restart mysqld
实战案例:数据库操作与恢复
2.1 初始数据状态
我们的测试表中初始包含三条记录:
mysql> select * from test.person;+------+------+------+| id | name | age |+------+------+------+| 1 | San | 19 || 2 | mike | 23 || 3 | li | 20 |+------+------+------+
以下操作不会记录在二进制日志文件中,因为它们是原有的数据操作。
2.2 数据变更操作
接下来我们执行了一系列操作:
插入了一条新记录(wang)更新了mike的年龄删除了id为3的记录
执行这些操作后,数据状态如下:
mysql> insert into test.person values(4,'wang',10);Query OK, 1 row affected (0.00 sec)mysql> update test.person set age = 66 where name='mike';Query OK, 1 row affected (0.00 sec)Rows matched: 1 Changed: 1 Warnings: 0
mysql> delete from test.person where id = 3;Query OK, 1 row affected (0.01 sec)
这是数据更改后的操作
mysql> select * from test.person ;+------+------+------+| id | name | age |+------+------+------+| 1 | San | 19 || 2 | mike | 66 || 4 | wang | 10 |+------+------+------+3 rows in set (0.00 sec)

查看二进制文件:
怪兽AI数字人
数字人短视频创作,数字人直播,实时驱动数字人
44 查看详情
-- 查看二进制日志文件列表mysql> SHOW BINARY LOGS;-- 查看当前正在写入的二进制日志文件mysql> SHOW MASTER STATUS;
-- 查看二进制日志事件mysql> SHOW BINLOG EVENTS IN 'mysql-bin.000001';

2.3 数据丢失模拟与恢复
假设发生了意外,所有数据被删除:
mysql> delete from test.person;Query OK, 3 rows affected (0.00 sec)mysql> select * from test.person;Empty set (0.00 sec)

2.4 恢复数据
这时,我们可以使用二进制日志来恢复数据。我们需要恢复到插入id=4,name=wang的数据之前的状态,包括它:
mysqlbinlog --stop-position="2435" /usr/local/mysql/data/mysql-bin.000001 | mysql -u root -p
数据恢复成功。

以上就是MySQL数据库:基于二进制日志的数据恢复实战的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/486649.html
微信扫一扫
支付宝扫一扫