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中的数据和偏移量。

posted @ 2019-07-26 10:36  lightyear  阅读(236)  评论(0编辑  收藏  举报