MySQL数据库可以实现主从复制,实现持久化,实现回滚,其关键在于MySQL里的三种log,分别是:
binlog : (server层)主从复制和数据恢复。
redo log :一致性(保证数据不丢失)、性能(记录事务对数据页做了哪些修改)
undo log:原子性保证、MVCC
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文件内容。
会记录每条变更的sql语句,还有执行开始时间,结束时间,事务id等信息。
使用命令show variables like '%log_bin%';
查看binlog是否打开。
找到my.cnf配置文件,增加下面配置(mysql版本5.7.31):
# 打开binlog
log-bin=mysql-bin
# 选择ROW(行)模式
binlog