🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
### binlog > binlog日志用于记录所有更新且提交了数据或者已经潜在更新提交了数据(例如,没有匹配任何行的一个DELETE)的所有语句。语句以“事件”的形式保存,它描述数据更改。 **binlog作用** 1. 恢复使能够最大可能地更新数据库,因为二进制日志包含备份后进行的所有更新。 2. 在主复制服务器上记录所有将发送给从服务器的语句。 ### undo log > Undo Log是为了实现事务的原子性,在MySQL数据库InnoDB存储引擎中,还用UndoLog来实现多版本并发控制(简称:MVCC)。 > 实现原子性和持久化的事务的简化过程 - **事务的原子性(Atomicity) ** > 事务中的所有操作,要么全部完成,要么不做任何操作,不能只做部分操作。如果在执行的过程中发了错误,要回滚(Rollback)到事务开始前的状态,就像这个事务从来没有执行过。 - **原理 ** > Undo Log的原理很简单,为了满足事务的原子性,在操作任何数据之前,首先将数据备份到一个地方(这个存储数据备份的地方称为UndoLog)。 > 然后进行数据的修改。如果出现了错误或者用户执行了ROLLBACK语句,系统可以利用UndoLog中的备份将数据恢复到事务开始之前的状态。 > 除了可以保证事务的原子性,Undo Log也可以用来辅助完成事务的持久化。 - **事务的持久性(Durability) ** > 事务一旦完成,该事务对数据库所做的所有修改都会持久的保存到数据库中。为了保证持久性,数据库系统会将修改后的数据完全的记录到持久的存储上。 ### redo log > 记录的是新数据的备份。在事务提交前,只要将Redo Log持久化即可,不需要将数据持久化。当系统崩溃时,虽然数据没有持久化, 但是RedoLog已经持久化。系统可以根据RedoLog的内容,将所有数据恢复到最新的状态。 **Undo+Redo** 事务的特点 A.为了保证持久性,必须在事务提交前将RedoLog持久化。 B.数据不需要在事务提交前写入磁盘,而是缓存在内存中。 C.RedoLog保证事务的持久性。 D.UndoLog保证事务的原子性。 E.有一个隐含的特点,数据必须要晚于redolog写入持久