I have a file indexing database on Linux. Currently I use file path as an identifier. But if a file is moved/renamed, its path is changed and I cannot match my DB record to the new file and have to delete/recreate the record. Even worse, if a directory is moved/renamed, then I have to delete/recreate records for all files and nested directories.
I would like to use inode number as a unique file identifier, but inode number can be reused if file is deleted and another file created.
So, I wonder whether I can use a pair of {inode,crtime}
as a unique file identifier.
I hope to use i_crtime on ext4 and creation_time on NTFS.
In my limited testing (with ext4) inode and crtime do, indeed, remain unchanged when renaming or moving files or directories within the same file system.
So, the question is whether there are cases when inode or crtime of a file may change. For example, can fsck or defragmentation or partition resizing change inode or crtime or a file?
Interesting that http://msdn.microsoft.com/en-us/library/aa363788%28VS.85%29.aspx says:
- "In the NTFS file system, a file keeps the same file ID until it is deleted."
but also: - "In some cases, the file ID for a file can change over time."
So, what are those cases they mentioned?
Note that I studied similar questions:
- How to determine the uniqueness of a file in linux?
- Executing 'mv A B': Will the 'inode' be changed?
- Best approach to detecting a move or rename to a file in Linux?
but they do not answer my question.
See Question&Answers more detail:os