zoukankan      html  css  js  c++  java
  • double write 双写

    Oracle 8KB Postgresql 8KB MySQL Innodb 16KB buffer page block
    首先,要DML数据,需要先把page读取到index page中,之后对内存中的page中的数据进行DML操作
    ,磁盘读数据到内存是同步。
    从内存写入到磁盘是异步的,假设从内存insert写入到磁盘16KB的Page到磁盘,一个Page写到8k的时候
    突然断电了,这时候该Page就处于无法恢复状态(Oracle在这块是无法处理的,Oracle是需要操作系统来处理的,MySQL是有办法处理该问题的),可能会想可以通过redo log恢复,但是这种情况下redo是无法做恢复的,因为这种情况内存中的Page是损坏的,因为每个page的头部有一个校验和(Checksum)尾部也有一个校验和(Checksum)当page写完之后才会将两个校验和一致,因为page中的校验和在写入磁盘的block中的过程中断电损坏了,所以page的头和尾的校验就不一致了。redo无法恢复page的部分损坏的情况因为redo中没有保留page的完全镜像,redo中保存的只是page中的数据和偏移量。

  • 相关阅读:
    Mysql InnoDB引擎下 事务的隔离级别
    Spring 两大核心 IOC 和 AOP
    java 冒泡排序
    MyBatis 传入List集合作为条件查询数据
    fastfusion运行
    数据集
    工具学习
    三维重建
    Scrivener破解
    博客园设置
  • 原文地址:https://www.cnblogs.com/dbalightyear/p/11248778.html
Copyright © 2011-2022 走看看