02、MySql Server中的BinLog

本文详细介绍了MySQL的binlog日志和redolog日志,binlog并非InnoDB独有,而是MySQL服务器的日志。binlog在事务提交时与redolog同步写入,sync_binlog参数控制刷盘策略。当binlog写入磁盘后,将binlog文件名和位置记录到redolog,并写入commit标记,确保日志一致性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、binlog日志

binlog叫做归档日志 binlog不是InnoDB存储引擎特有的日志文件(redo log 属于InnoDB存储引擎特有的),是属于mysql server 自己的日志文件

提交事务的时候会把redo log 日志写到磁盘文件中去,同时也会把这次更新对应的binlog 日志写入到磁盘文件中去

2、binlog 日志的刷盘策略

sync_binlog参数可以控制binlog的刷盘策略,默认值是 0
2.1、为0时 :在提交事务的时候 是先写入 os cache缓存中,此时如果宕机os cache 里的binlog日志是会丢失的
2.2 为1时:提交事务的时候,会把binlog日志直接写入到磁盘中(比较强硬,提交数据就不会丢失)

3、基于binlog 和redo log完成事务的提交

当我们吧binlog 写入磁盘文件后,此时会把本次更新的binlog 文件名称和这次更新binlog日志在文件里的位置,写入到redo log 日志文件中,并同时redo log日志文件里写入commit标记这样事务才算完事!

4、最后一步redo日志写入commit标记的意义是什么?

目的是为了保持 redo log日志与binlog 日志的一致

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值