MySQL如何保证数据不丢失

实现技术基础

MySQL 的两阶段提交 + WAL技术(Write-Ahead Logging,先写日志再写盘),这两个结合在一起保证了数据不会丢失。

先来看看 MySQL 两阶段提交和WAL流程

在这里插入图片描述

binlog

binlog 在一个事务内,先将 binlog 写到 binlog buffer,然后在write binlog files,然后再 fsync 到磁盘,这里根据参数 sync_binlog 进行控制:

  • 设置0:表示事务提交只 write,不 fsync
  • 设置1:表示事务提交 write 后,立马 fsync
  • 设置N:表示事务提交 write 积累到N条后,才 fsync

设置N的风险是如果主机掉电,N条记录会丢失的风险

redo log

redo log 事务从 redo log bufferredo logo buffer 是在 MySQL 进程中的) writelinux 文件系统的 page cache ,然后在 fsync 到磁盘,
这里根据参数 innodb_flush_log_at_trx_commit 参数控制 writefsync 时机:

  • 设置0:表示每次事务提交只留在 redo log buffer
  • 设置1:表示每次事务提交都 fsync 到磁盘
  • 设置2:表示每次事务提交都只写到 page cache

innodb后台有一个线程,每秒 redo logredo log buffer writepage cache,然后 fsync 到磁盘,除了线程轮询,MySQL 还有两种将 redo log fsync 到磁盘的时机

  • redo log buffer 占用的空间即将达到 innodb_log_buffer_size 一半的时候,innodb 会将 redo log buffer 里的 redo log writepage cache,(也就是说,一个还没有提交事务的 redo log,也可能已经被持久化到磁盘了)
  • 并行的事务提交的时候,顺带将这个事务的 redo log buffer 持久化到磁盘。前提是 innodb_flush_log_at_trx_commit 设置的是1

组提交

MySQL这样设计的好处是,可以组提交,交叉 fsync。 一组 fsync 收集的 write 越多, 对应的磁盘的IO越少,提高 MySQL 性能。
因此,WAL的优势在于:

  • redo log & binlog 都是按顺序写入磁盘的,比随机写磁盘速度快。
  • 组提交机制,合并fsync。大幅度降低磁盘的 IOPS 消耗,提高IO性能。

全景图

在这里插入图片描述

参考文献

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值