MINIX内部碎片2

时间:2011-12-11 20:07:21

标签: c stat minix

我正在用C编写一些软件,递归列出给定目录中的所有文件,现在我需要计算出内部碎片。

我花了很长时间研究这个并发现ext2上的内部碎片只发生在最后一个块中。我知道从理论上的inode数字你应该能够获得第一个和最后一个块地址,但我不知道如何。

我调查了stat()fcntl()以及各种各样的方法。如何从inode编号中获取最后一个块地址?

我还想到,一旦我拥有了最后一个块的地址,我就可以测试该块中有多少可用空间,这将给我内部碎片。

我知道有get_inodeget_block命令,但除此之外不知道!

2 个答案:

答案 0 :(得分:1)

我认为您不能通过常规系统调用(例如stat())获取磁盘块的地址。您可能必须在磁盘上找到原始inode(这意味着访问原始磁盘,并需要提升权限)并从那里处理数据。

通常,您可以找到文件的直接块,间接块,双间接块和三重间接块。但是,相关的文件系统类型和dodo一样死(我不认为我已经看到了这个千年的文件系统类型),所以现在不太可能有太多帮助。

可能会有一个非标准的系统调用来获取信息,但我对此表示怀疑。

答案 1 :(得分:1)

也许你认为太复杂了,但如果你把文件大小除以块大小并取模数,大致应该能够计算内部碎片。

但这仅在文件是“经典文件”时才有效 - 稀疏文件或文件包含很多“其他信息”(例如巨大的ACL或扩展属性),可能会有所不同。 (我不知道它们存储在哪里,但我可以想象可能有文件系统将它们存储在最后一个块中,有效地(但不会引人注意地)减少内部碎片。)