mysql持久化原理?
持久化定義
持久化是指事務一旦提交,它對數據庫的改變就應該是永久性的,接下來的其他操作或故障不應該對本次事務的修改有任何影響。
我們知道InnoDB使用 Buffer Pool 來提高讀寫的性能。但是 Buffer Pool 是在內存的,是易失性的,如果一個事務提交了事務后,MySQL突然宕機,且此時Buffer Pool中修改的數據還沒有刷新到磁盤中的話,就會導致數據的丟失,事務的持久性就無法保證。
為了解決這個問題,InnoDB引入了 redo log來實現數據修改的持久化。當數據修改時,InnoDB除了修改Buffer Pool中的數據,還會在redo log 記錄這次操作,并保證redo log早于對應的頁面落盤(一般在事務提交的時候),也就是常說的WAL。若MySQL突然宕機了且還沒有把數據刷回磁盤,重啟后,MySQL會通過已經寫入磁盤的redo log來恢復沒有被刷新到磁盤的數據頁。
實現原理:redo log
為了提高性能,和數據頁類似,redo log 也包括兩部分:一是內存中的日志緩沖(redo log buffer),該部分日志是易失性的;二是磁盤上的重做日志文件(redo log file),該部分日志是持久的。redo log是物理日志,記錄的是數據庫中物理頁的情況 。
當數據發生修改時,InnoDB不僅會修改Buffer Pool中的數據,也會在redo log buffer記錄這次操作;當事務提交時,會對redo log buffer進行刷盤,記錄到redo log file中。如果MySQL宕機,重啟時可以讀取redo log file中的數據,對數據庫進行恢復。這樣就不需要每次提交事務都實時進行刷臟了。
大概就是這些,還有就是出現意外關機,需要數據恢復的,持久化這塊也可以做到的。