mysql三大日志 undolog,redolog,undolog

Mysql三大日志

(1)bin log日志是用在主从复制场景下,跟事务没有什么关系

将master数据库的增删改SQL语句以二进制的形式记录到bin log日志里面,然后将这个binlog日志发送给slave数据库,slave数据库执行binlog日志中的增删改sql语句来达到和master数据库数据一致

(2)undo log和redo log   

①undo log里面存的是数据被修改之前的数据,redo log存的是数据被修改之后的数据

执行undo log会回滚到事务执行前的数据,可以保证原子性

当数据库宕机了,数据库执行redo log可以将数据恢复到事务执行后的版本,可以保证持久性

②undo log是逻辑日志(针对的是每一行的记录),存储的是数据修改的逆操作(如果执行了一条 UPDATE 语句将某个字段的值从 10 修改为 15,那么 Undo Log 中就会记录一个相应的逆操作,将这个字段的值从 15 修改回 10。但不是完整的sql语句)redo log是物理日志(针对的是整个物理页),磁盘中哪一页的哪个数据被改成什么了

能不能用redo log替代bin log?

不能,因为(1)bin log是满了会再起一个新的bin log文件,redo log满了会覆盖之前的redo log

(2)bin log是逻辑日志,redo log是物理日志,记录的是哪个数据页的哪个数据被改成什么了,在不同的机器上数据的位置是不一样的,可能在这个机器上是在这个数据页上,在另一台机器,就是在另一个数据页上

猜你喜欢

转载自blog.csdn.net/weixin_47414034/article/details/132668116
今日推荐