WAL技术

作者: 技术灭霸 | 来源:发表于2020-05-12 01:08 被阅读0次

WAL(Write Ahead Log)预写日志,它的关键点就是先写日志,再写磁盘,是数据库系统中常见的一种手段,用于保证数据操作的原子性和持久性。

在使用 WAL 的系统中,所有的修改在提交之前都要先写入 log 文件中。

log 文件中通常包括 redo 和 undo 信息。这样做的目的可以通过一个例子来说明。假设一个程序在执行某些操作的过程中机器掉电了。在重新启动时,程序可能需要知道当时执行的操作是成功了还是部分成功或者是失败了。如果使用了 WAL,程序就可以检查 log 文件,并对突然掉电时计划执行的操作内容跟实际上执行的操作内容进行比较。在这个比较的基础上,程序就可以决定是撤销已做的操作还是继续完成已做的操作,或者是保持原样。

WAL 的优点

  1. 读和写可以完全地并发执行,不会互相阻塞(但是写之间仍然不能并发)。
  2. WAL 在大多数情况下,拥有更好的性能(因为无需每次写入时都要写两个文件)。
  3. 磁盘 I/O 行为更容易被预测。
  4. 使用更少的 fsync()操作,减少系统脆弱的问题。

相关文章

  • WAL技术

    WAL(Write Ahead Log)预写日志,它的关键点就是先写日志,再写磁盘,是数据库系统中常见的一种手段,...

  • redo log和binlog

    redo log与WAL技术 redo log的WAL技术可以与孔乙己赊账的粉板类似。当店里生意较忙的时候,有人要...

  • MySql事务之两阶段提交与redo log、binlog

    redo log 为了保证事务的持久性,mysql的InnoDB采用了WAL 技术,WAL 的全称是 Write-...

  • mysql两阶段提交

    1.两阶段提交 MySQL中经常说的WAL技术,WAL的全称是Write- Ahead Logging,它的关键点...

  • redo log 和 binlog

    mysql里面常说的WAL技术,即Write-Ahead Logging => 先写日志,再写磁盘。 redo l...

  • HBase-内部优化

    1 WAL优化 一个Region有一个WAL实例,WAL实例启动后再内存中维护了一个ConcurrentNavig...

  • WAL

    WAL -------------- Write Ahead Logs sparkstreaming的容错机制,...

  • 05. HBase WAL解析

    什么是预写日志WAL(Write-Ahead-Log)? HBase的Write Ahead Log (WAL)提...

  • 【容错篇】WAL在Spark Streaming中的应用

    【容错篇】WAL在Spark Streaming中的应用 WAL 即 write ahead log(预写日志),...

  • HBase-WAL

    为什么要把 WAL 加载到 MemStore中,再刷写成 HFile 呢? WAL (Write-Ahead-Lo...

网友评论

      本文标题:WAL技术

      本文链接:https://www.haomeiwen.com/subject/yxnmnhtx.html