mysql日志

本文详细介绍了MySQL中的binlog、redo log和undo log。binlog用于主从复制和数据恢复,记录表结构和数据的变更;redo log确保数据一致性,记录事务对数据页的修改;undo log则用于事务回滚和MVCC。文章讨论了不同日志格式、刷盘时机及它们的区别。
摘要由CSDN通过智能技术生成

MySQL数据库可以实现主从复制,实现持久化,实现回滚,其关键在于MySQL里的三种log,分别是:
binlog : (server层)主从复制和数据恢复。
redo log :一致性(保证数据不丢失)、性能(记录事务对数据页做了哪些修改)
undo log:原子性保证、MVCC
mysql架构

binlog

用于记录数据库 表结构和表数据变更 的二进制日志,比如insert、update、delete、create、truncate等等操作,不会记录查询(select、show)操作;

binlog是通过追加的方式进行写入的,可以通过max_binlog_size参数设置每个binlog文件的大小,当文件大小达到给定值之后,会生成新的文件来保存日志。
执行SHOW MASTER STATUS;可以查看当前写入的binlog文件名。

binlog日志格式

三种:STATMENT(基于SQL语句的复制)、ROW(行)和MIXED(混合复制)

MySQL 5.7.7之前,默认的格式是STATEMENT
MySQL 5.7.7之后,默认值是ROW。日志格式通过binlog-format指定。

使用mysqlbinlog命令可以查看binlog文件内容。binlog文件内容
会记录每条变更的sql语句,还有执行开始时间,结束时间,事务id等信息。
使用命令show variables like '%log_bin%';查看binlog是否打开。
找到my.cnf配置文件,增加下面配置(mysql版本5.7.31):

# 打开binlog
log-bin=mysql-bin
# 选择ROW()模式
binlog
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值