EXT4 支持多种日志模式,如 journal、ordered(默认模式)和 writeback 等。不同模式在数据和元数据的处理上有所差异。
journal 模式:提供了完全的数据块和元数据块的日志,所有的数据都会先写入到日志里,然后再写入磁盘(掉电非易失存储介质)上。在文件系统崩溃的时候,日志就可以进行重放,把数据和元数据带回到一个一致性的状态,journal 模式性能是三种模式中最低的,因为所有的数据都需要日志来记录。这个模式不支持 allocation以及 o_direct。
ordered 模式:只提供元数据的日志,但它逻辑上将与数据更改相关的元数据信息与数据块分组到一个称为事务的单元中。当需要把元数据写入到磁盘上的时候,与元数据关联的数据块会首先写入,也就是数据先落盘,再做元数据的日志。一般情况下,这种模式的性能会略逊色于 writeback 但是比 journal 模式要快得多。
writeback 模式:当元数据提交到日志后,data 可以直接被提交到磁盘,即会做元数据日志,数据不做日志,并且不保证数据比元数据先落盘,writeback 是 EXT4 提供的性能最好的模式。
在实现过程中,涉及到的主要数据结构包括:
- buffer_head:内核用于管理磁盘缓冲区的数据结构,一个 buffer_head 对应一个文件系统块(通常为 512 字节大小),用于跟踪从磁盘加载到内存的块数据。一个 transactio