1. ntfs源码分析 ntfs文件系统中mft的b+树

本文深入探讨NTFS文件系统的MFT如何利用B+树进行数据存储,通过分析ntfs_read和ntfs_attr_find_vcn等关键函数,揭示B+树在NTFS中的应用和流程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一直好奇 ntfs文件系统 的mft 是如何使用 b+树的, 今天开始好好把ntfs使用b+树的流程整理出来,
涉及到的代码为 ntfs-3g ntfsprogs 的代码在个人的下载里面有.
废话不说开始分析.
G:_xfile_all_xfile_2020_05\linux_src_chm_2010\ntfs-3g-20070920-BETA.chm

1. MFT的数据结构

ntfscat /dev/sda6 \$MFT 

mft 属性

typedef enum {
   
        AT_UNUSED                       = const_cpu_to_le32(         0),
        AT_STANDARD_INFORMATION         = const_cpu_to_le32(      0x10),
        AT_ATTRIBUTE_LIST               = const_cpu_to_le32(      0x20),
        AT_FILE_NAME                    = const_cpu_to_le32(      0x30),
        AT_OBJECT_ID                    = const_cpu_to_le32(      0x40),
        AT_SECURITY_DESCRIPTOR          = const_cpu_to_le32(      0x50),
        AT_VOLUME_NAME                  = const_cpu_to_le32(      0x60),
        AT_VOLUME_INFORMATION           = const_cpu_to_le32(      0x70),
        AT_DATA                         = const_cpu_to_le32(      0x80),
        AT_INDEX_ROOT                   = const_cpu_to_le32(      0x90),
        AT_INDEX_ALLOCATION             = const_cpu_to_le32(      0xa0),
        AT_BITMAP                       = const_cpu_to_le32(      0xb0),
        AT_REPARSE_POINT                = const_cpu_to_le32(      0xc0),
        AT_EA_INFORMATION               = const_cpu_to_le32(      0xd0),
        AT_EA                           = const_cpu_to_le32(      0xe0),
        AT_PROPERTY_SET                 = const_cpu_to_le32(      0xf0),
        AT_LOGGED_UTILITY_STREAM        = const_cpu_to_le32(     0x100),
        AT_FIRST_USER_DEFINED_ATTRIBUTE = const_cpu_to_le32(    0x1000),
        AT_END                          = const_cpu_to_le32(0xffffffff),
}</
解析NTFS底层结构 一、NTFS系统结构 NTFS是Windows NT引入的新型文件系统,如果您是一位熟悉FAT磁盘格式的专业人士,您可能会觉得NTFS系统的思想蹩脚而晦涩,如果您对FAT格式一无所知,那么恭喜您,您会更快的了解这种更有效率的磁盘格式NTFS的结构复杂,内容繁多,笔者仅对NTFS卷上的底层结构做分析,并提供卷上数据删除的特征状态供大家参考。 现在,我们首先来建立了解NTFS需要的基本概念。 1.0基本结构及基本概念 在NTFS中,文件以簇的形式分配。最小的单位为扇区,N个扇区为一簇。其中,N的值可以通过BPB(引导扇区)读出(以下会详细介绍)。 1.0.1卷与簇 卷大小(分区大小) 每簇的扇区 缺省的簇大小 小于等于512MB 1 512字节 513MB~1024MB(1GB) 2 1024字节(1KB) 1025MB~2048MB(2GB) 4 2048字节(2KB) 大于等于2049MB 8 4KB 表1 卷与簇的关系 从上面可以看出,也就是说不管驱动器多大NTFS簇的大小不会超过4KB。 1.0.2 NTFS的基本数据结构 NTFS的数据大体上可分为4个部分 (1) Partition boot sector(引导扇区,又称BPB),此部分为所有磁盘格式都共有,占用一个扇区,但是具体的内容当然各不相同(见表3)。 (2) Master File Table(主文件列表,MFT),它是对卷上所有文件的记录,每一个文件对应一个记录项,理论上占用该卷12%的空间。 (3) System files(系统文件),NTFS系统一共有16个系统文件,和8个保留文件。 (4) File area(数据区),留给用户的空间。 Partition boot sector 引导扇区 Master File Table 主文件列表 System files 系统文件 File area 用户文件区(数据区) 表2 NTFS的磁盘分配情况
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值