说一说 MySQL 的 redolog 和 binlog?
面试宝典
2023-06-12
Web前端开发工程师
47
MySQL中的redolog和binlog都是记录数据库操作的机制,但它们的目的和功能略有不同:
1. Redolog(redo log)
redo log是MySQL内部用于实现事务的机制。在执行一条SQL语句时,MySQL会将相关的数据页从磁盘读入内存中进行操作,然后再将数据同步回磁盘。但如果在操作过程中发生了宕机等异常情况,数据可能只写入到了内存中,没有写入磁盘。这时,如果使用redo log,可以将内存中的数据变更操作记录到redo log中,它可以保证在MySQL重启后将未被写入磁盘的数据恢复到磁盘上。
2. Binlog(binary log)
binlog是一种记录MySQL数据库中所有修改的日志。它记录了所有的增、删、改操作,但不包含查询操作。它适合于数据恢复、数据同步以及数据安全等应用场景。可以将binlog中的内容复制到其他服务器上,实现数据同步,或者使用binlog恢复数据库到之前的某个时间点的状态。
总体来说,redo log是MySQL内部实现事务的机制,用于保证数据的完整性和一致性;而binlog则是MySQL记录所有修改的机制,用于数据的备份、同步和恢复。
1. Redolog(redo log)
redo log是MySQL内部用于实现事务的机制。在执行一条SQL语句时,MySQL会将相关的数据页从磁盘读入内存中进行操作,然后再将数据同步回磁盘。但如果在操作过程中发生了宕机等异常情况,数据可能只写入到了内存中,没有写入磁盘。这时,如果使用redo log,可以将内存中的数据变更操作记录到redo log中,它可以保证在MySQL重启后将未被写入磁盘的数据恢复到磁盘上。
2. Binlog(binary log)
binlog是一种记录MySQL数据库中所有修改的日志。它记录了所有的增、删、改操作,但不包含查询操作。它适合于数据恢复、数据同步以及数据安全等应用场景。可以将binlog中的内容复制到其他服务器上,实现数据同步,或者使用binlog恢复数据库到之前的某个时间点的状态。
总体来说,redo log是MySQL内部实现事务的机制,用于保证数据的完整性和一致性;而binlog则是MySQL记录所有修改的机制,用于数据的备份、同步和恢复。
-
上一篇
说一说 MySQL 的 redolog 和 binlog?
<p> (1)MySQL 分两层:Server (服务器) 层和引擎层。区别如下:</p><p> Server (服务器) 层:主要做的是 MySQL 功能层面的事情。Server (服务器) 层也有自己的日志,称为 binlog(归档日志)</p><p> 引擎层:负责存储相关的具体事宜。redo log 是 InnoDB 引擎特有的日志。</p><p> (2)redo log 是物理日志,记录的是“在某个数据页上做了什么修改”;binlog 是逻辑日志,记录的是这个语句的原始逻辑,比如“给 ID=2 这一行的 c 字段加 1 ”。</p><p> (3)redo log 是循环写的,空间固定会用完;</p><p> (4)binlog 是可以追加写入的。“追加写”是指 binlog 文件写到一定大小后会切换到下一个,并不会覆盖以前的日志。</p>
-
下一篇
说一说 MySQL 的 redolog 和 binlog?
说一说 MySQL 的 redolog 和 binlog?
相关文章
- 请举例说明PHP中如何处理异常?
- 请问PHP中如何实现多线程?
- 请解释一下PHP中的MVC模式是如何工作的?
- PHP7和PHP5的性能上有什么差别?
- 请描述在Golang中使用MongoDB时的最佳实践。
- 请解释什么是defer语句,以及它有什么作用?
- 请提供至少三个通过PHP实现的网站性能优化技巧。
- 如何通过PHP来保护您的代码免受SQL注入攻击?
- 聊一下高并发和高性能的区别和联系?
- PHP中如何处理文件上传和下载?
- 如何在Golang中进行并发编程?
- 请谈谈您对PHP的垃圾回收机制的了解及实践。
- PHP中如何进行单元测试以及如何在开发过程中保证代码质量?
- 请列出与PHP相关的缓存机制及其优缺点。
- 在PHP中,Magic Method都有哪些,并举例说明它们的作用?
- 请解释HTTP的基本概念,以及在Golang中如何使用HTTP?
- 请给一个例子解释一下PHP中的闭包函数是什么?
- PHP中常用的设计模式有哪些?
- 请解释下PHP中会话(session)和Cookie(cookie)的作用。
- 如何在Golang中实现单例模式?
微信收款码
支付宝收款码