binlog 和 redolog 有什么区别

编程入门 行业动态 更新时间:2024-10-27 14:32:10

binlog 和 redolog <a href=https://www.elefans.com/category/jswz/34/1771105.html style=有什么区别"/>

binlog 和 redolog 有什么区别

binlog 和 redolog 都是 Mysql 里面用来记录数据库数据变更操作的日志.

binlog

其中 binlog 主要用来做数据备份、数据恢复和数据同步,在Mysql 的主从数据同步的场景中,master 节点的数据变更,会写入到 binlog 中,然后再把 binlog 中的数据通过网络传输给slave 节点,实现数据同步。

redolog

redolog,主要是在 Mysql 数据库事务的 ACID 特性里面,用来保证数据的持久化特性。但是其实它还有很多的作用。比如数据库崩溃时,可以通过 Redo Log 来恢复未完成的数据,保证数据的完整性。通过合理的配置 Redo Log 的大小和数量,还可以优化 Mysql 的性能。

总结

binlog 和 redolog 的区别有很多,可以简单总结三个点: 

  • 记录的信息不同,binlog 是记录数据库的逻辑变化,它提供了三种日志格式分别是 statement,row 以及 mixed; redo log 记录的是物理变化,也就是数据页的变化结果。
  • 使用场景不同,binlog 主要用来做数据备份、数据恢复、以及主从集群的数据同步;Redo Log 主要用来实现 Mysql 数据库的事务恢复,保证事务的 ACID 特性。当数据库出现崩溃的时候,Redo Log 可以把未提交的事务回滚,把已提交的事务进行持久化,从而保证数据的一致性和持久性。
  • 记录的时机不同, binlog 是在执行 SQL 语句的时候,在主线程中生成逻辑变化写入到磁盘中,所以它是语句级别的记录方式; RedoLog 是在 InnoDB 存储引擎层面的操作,它是在 Mysql 后台线程中生成并写入到磁盘中的,所以它是事务级别的记录方式,一个事务操作完成以后才会被写入到 redo log 中。

更多推荐

binlog 和 redolog 有什么区别

本文发布于:2023-12-04 18:32:05,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1661844.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:有什么区别   binlog   redolog

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!