Linux file deleted recovery

前端 未结 3 1489
时光说笑
时光说笑 2021-02-09 02:17

Is there a way to create a file in Linux that link to a specific iNode? Take this scenario: There is a file that is in course of writing (a log maybe) and the specific file is d

相关标签:
3条回答
  • 2021-02-09 02:51

    It's always difficult to answer a question like "can I do" confidently in the negative. But as far as I see, neither /sys/ nor /proc provide a mapping of open files descriptors that are not symlinks. I assume by "BUT a link in the dir /proc is still pointing at it" you mean that the /proc//fd/ entries look like symlinks? I'm almost sure you cannot recover the original file.

    I take that back: As user user2676075 pointed out, copying does work. Just hardlinking doesn't ...

    UPDATE: If you think about it, it's quite logical.

    • /proc and /sys are file systems different from your hard disk. So they can't provide file like directory entries which one could hardlink to a destination on the hard disk.
    • The /proc/*/fd/ entries pretend to be symlinks, but actually they are different, else the copying would not work. I think they pretend to be symlinks to provide meaningful information with 'ln -l'.

    • Regarding the (missing) capability to hardlink to some inode (let's say with some system call): This cannot be part of the kernel or the VFS-Interface, for the following reasons:

      • It would violate the integrity of the file system. The filesystem is not supposed to keep the disk blocks of files that are completely deleted around in the same manner as files that persist.

      • The inodes might be a completely virtual concept to identify a "slot where a datastream is stored'. I assume there can be implementations that would have a problem converting a slot that has no reference back to a slot which is refered to by a name in the file system.

      I admit the case against the possibility of such a system call is not water tight. But given the current state of the VFS interface (which AFAIR doesn't provide for such a call), it would be a heavy burden for any file system implementation (including e.g. distributed file systems) to provide a call to link a file into a directory by inode.

    ATM I wonder if calling fstat before and after deleting the last reference is actually requires to return the same inode information ... t

    0 讨论(0)
  • 2021-02-09 03:06

    You can use lsof to recover deleted files (sometimes)...

    > lsof | grep testing.txt
    less    4607    juliet  4r  REG 254,4   21  
           8880214 /home/juliet/testing.txt (deleted)
    

    Be sure to read the original article for full details before attempting this, unless you're a Maveric like me.

    > ls -l /proc/4607/fd/4
    lr-x------ 1 juliet juliet 64 Apr  7 03:19 
             /proc/4607/fd/4 -> /home/juliet/testing.txt (deleted)
    > cp /proc/4607/fd/4 testing.txt.bk
    

    http://www.linuxplanet.com/linuxplanet/tips/6767/1

    Enjoy

    0 讨论(0)
  • 2021-02-09 03:08

    Since there is no Syscall that involves iNode, because is a concept of extX fs and is not a good practice make a stove pipe but it is to make a chain of responsability (as M.E.L. suggests), there is only a NO answer for this question because at VFS level we handle files path and names and not other internal representations.

    BUT to achieve the goal to track the most last modification we can use a continous monitoring and duplication with tail:

    tail -c+1 -f --pid=PID /proc/PID/fd/FD > /path/to/the/copy
    

    where PID is the pid of the process that have the deleted file still opened and FD is its file descriptor number. With -f tail open and hold the file to display further modification, with -c+1 start to "tail" from the first byte and with --pid=PID tail is informed to exit when the pid exit.

    0 讨论(0)
提交回复
热议问题