MYSQL-二进制日志(Binlog)

MySQL Binlog详解

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

图片

数据库是一个系统(应用)最重要的资产之一,所以我们的数据库将从以下几个数据库来进行介绍。

MySQL(本章节)

PostgreSQL

MongoDB

Redis

Etcd

我们在前面在介绍中间件:ZooKeeper介绍过事务日志,在MYSQL里面其实有类似的东西,但是他们的功能并不相同。

一、什么是二进制日志(Binlog)

二进制日志(Binary Log)是 MySQL 服务层创建的一种逻辑日志,它记录了对 MySQL 数据库执行的所有更改数据的操作(DDL 和 DML),但不包括 SELECT 和 SHOW 这类不修改数据的操作。

它以二进制的、序列化的形式存储在磁盘上,是数据恢复、主从复制(Replication)等功能的核心基础。

核心特点:

  • 逻辑日志:它记录的是操作的逻辑(如 SQL 语句本身)或行的前后变化,而不是物理的数据页修改。

  • 追加写入:日志文件以追加模式写入,性能很好。

  • 事务安全:在支持事务的存储引擎(如 InnoDB)中,Binlog 与存储引擎的重做日志(Redo Log)协同工作,确保了数据的持久性和一致性(通过两阶段提交)。

二、二进制日志的主要作用

  1. 主从复制(Replication),这是 Binlog 最经典的作用。主库(Master)将其 Binlog 发送到从库(Slave),从库重放(Replay)这些日志事件,从而使得主从数据保持最终一致。它是 MySQL 实现高可用、读写分离和负载均衡的基础。

  2. 数据恢复(Point-in-Time Recovery, PITR)

    • 结合全量备份(如 mysqldump)和 Binlog,可以将数据库恢复到过去的任意时间点。

    • 过程:先恢复最近的全量备份,然后重放该备份时间点之后的所有 Binlog,直到错误发生前的某一个时刻。

  3. 审计(Audit)

    • 通过解析 Binlog,可以查看谁在什么时候对数据库做了哪些修改,用于安全审计和问题排查。

三、二进制日志的格式(Binlog Format)

Binlog 有三种记录格式,这直接影响复制的行为和数据的安全性。可以通过 binlog_format 参数进行设置。

格式

描述

优点

缺点

STATEMENT

 (SBR)

基于SQL语句的复制

。记录的是执行的原始SQL语句

日志文件小,节省磁盘和网络I/O。

不安全

。某些语句(如 NOW()RAND()UUID())在主从执行结果可能不一致。

ROW

 (RBR)

基于行的复制

。记录的是每一行数据被修改后的内容(或修改前的内容)。

最安全

。能绝对保证主从数据一致性。

日志文件大(例如一条 UPDATE 更新了100万行,STATEMENT 只记1条语句,而 ROW 会记录100万行变化)。

MIXED

 (MBR)

混合模式复制

。默认使用 STATEMENT,但在可能引起主从不一致的情况下,自动切换为 ROW 格式。

在安全性和性能之间取得平衡。

仍有极小的概率在某些复杂情况下出现问题。

强烈推荐: 在现代 MySQL 版本(5.7+,8.0+)中,默认并且强烈建议使用 ROW 格式,因为它提供了最强的数据一致性保证,这是数据安全最重要的考量。

运维小路

一个不会开发的运维!一个要学开发的运维!一个学不会开发的运维!欢迎大家骚扰的运维!

关注微信公众号《运维小路》获取更多内容。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值