Basic Idea: Logging
data:image/s3,"s3://crabby-images/da082/da082a2cb49c1fabdd495ea14579cbec3dcd6950" alt="" | Record REDO and UNDO information, for every update, in a log.
data:image/s3,"s3://crabby-images/e5644/e56449a76d4ef16a5496565b70661851c10bf218" alt="" | Sequential writes to log (put it on a separate disk).
data:image/s3,"s3://crabby-images/e5644/e56449a76d4ef16a5496565b70661851c10bf218" alt="" | Minimal info (diff) written to log, so multiple updates fit in a single log page.
| | |
data:image/s3,"s3://crabby-images/da082/da082a2cb49c1fabdd495ea14579cbec3dcd6950" alt="" | Log: An ordered list of REDO/UNDO actions
data:image/s3,"s3://crabby-images/e5644/e56449a76d4ef16a5496565b70661851c10bf218" alt="" | Log record contains:
<, pageID, offset, length, old data, new data>
data:image/s3,"s3://crabby-images/e5644/e56449a76d4ef16a5496565b70661851c10bf218" alt="" | and additional control info (which well see soon). | | |
|