作者介绍:简历上没有一个精通的运维工程师。请点击上方的蓝色《运维小路》关注我,下面的思维导图也是预计更新的内容和当前进度(不定时更新)。

数据库是一个系统(应用)最重要的资产之一,所以我们的数据库将从以下几个数据库来进行介绍。
MySQL(本章节)
PostgreSQL
MongoDB
Redis
Etcd
我们在前面在介绍中间件:ZooKeeper介绍过事务日志,在MYSQL里面其实有类似的东西,但是他们的功能并不相同。
一、什么是二进制日志(Binlog)
二进制日志(Binary Log)是 MySQL 服务层创建的一种逻辑日志,它记录了对 MySQL 数据库执行的所有更改数据的操作(DDL 和 DML),但不包括 SELECT 和 SHOW 这类不修改数据的操作。
它以二进制的、序列化的形式存储在磁盘上,是数据恢复、主从复制(Replication)等功能的核心基础。
核心特点:
-
逻辑日志:它记录的是操作的逻辑(如 SQL 语句本身)或行的前后变化,而不是物理的数据页修改。
-
追加写入:日志文件以追加模式写入,性能很好。
-
事务安全:在支持事务的存储引擎(如 InnoDB)中,Binlog 与存储引擎的重做日志(Redo Log)协同工作,确保了数据的持久性和一致性(通过两阶段提交)。
二、二进制日志的主要作用
-
主从复制(Replication),这是 Binlog 最经典的作用。主库(Master)将其 Binlog 发送到从库(Slave),从库重放(Replay)这些日志事件,从而使得主从数据保持最终一致。它是 MySQL 实现高可用、读写分离和负载均衡的基础。
-
数据恢复(Point-in-Time Recovery, PITR)
-
结合全量备份(如 mysqldump)和 Binlog,可以将数据库恢复到过去的任意时间点。
-
过程:先恢复最近的全量备份,然后重放该备份时间点之后的所有 Binlog,直到错误发生前的某一个时刻。
-
-
审计(Audit)
-
通过解析 Binlog,可以查看谁在什么时候对数据库做了哪些修改,用于安全审计和问题排查。
-
三、二进制日志的格式(Binlog Format)
Binlog 有三种记录格式,这直接影响复制的行为和数据的安全性。可以通过 binlog_format 参数进行设置。
| 格式 | 描述 | 优点 | 缺点 |
|---|---|---|---|
| STATEMENT ( | 基于SQL语句的复制 。记录的是执行的原始SQL语句。 | 日志文件小,节省磁盘和网络I/O。 | 不安全 。某些语句(如 |
| ROW ( | 基于行的复制 。记录的是每一行数据被修改后的内容(或修改前的内容)。 | 最安全 。能绝对保证主从数据一致性。 | 日志文件大(例如一条 |
| MIXED ( | 混合模式复制 。默认使用 | 在安全性和性能之间取得平衡。 | 仍有极小的概率在某些复杂情况下出现问题。 |
强烈推荐: 在现代 MySQL 版本(5.7+,8.0+)中,默认并且强烈建议使用 ROW 格式,因为它提供了最强的数据一致性保证,这是数据安全最重要的考量。
运维小路
一个不会开发的运维!一个要学开发的运维!一个学不会开发的运维!欢迎大家骚扰的运维!
关注微信公众号《运维小路》获取更多内容。
MySQL Binlog详解

被折叠的 条评论
为什么被折叠?



