Linux or UNIX Recover deleted files – undelete files

Posted on in Categories Backup, Data recovery, Linux, Sys admin, Tips, UNIX last updated December 18, 2004

If you rum rm command accidentally and deleted important a file, recovery becomes critical under Linux and/or UNIX oses.

Since Linux is multiuser and multitasking operating system other users/process can overwrite deleted file disk space. So you need to take down system to single user mode.

First use wall (only the super-user can write on the terminals of users) command write a message to all users, then use init (process control initialization) command to take system to single user mode.

Procedure

Following are generic steps to recover text files.

First use wall command to tell user that system is going down in a single user mode:
# wallOutput:

System is going down to .... please save your work.

Press CTRL+D to send message.

Next use init 1 command to take system to a single user mode:
# init 1

Using grep (traditional UNIX way) to recover files

Use following grep syntax:
grep -b ‘search-text’ /dev/partition > file.txt
OR
grep -a -B[size before] -A[size after] ‘text’ /dev/[your_partition] > file.txt
Where,

  • -i : Ignore case distinctions in both the PATTERN and the input files i.e. match both uppercase and lowercase character.
  • -a : Process a binary file as if it were text
  • -B Print number lines/size of leading context before matching lines.
  • -A: Print number lines/size of trailing context after matching lines.

To recover text file starting with “nixCraft” word on /dev/sda1 you can try following command:
# grep -i -a -B10 -A100 'nixCraft' /dev/sda1 > file.txt

Next use vi to see file.txt. This method is ONLY useful if deleted file is text file. If you are using ext2 file system, try out recover command. .

See also:

Posted by: Vivek Gite

The author is the creator of nixCraft and a seasoned sysadmin and a trainer for the Linux operating system/Unix shell scripting. He has worked with global clients and in various industries, including IT, education, defense and space research, and the nonprofit sector. Follow him on Twitter, Facebook, Google+.

Share this on (or read 32 comments/add one below):

32 comment

  1. sridhar,

    There is no real undelete available (until and unless you go for 3rd party commercial software). Restore file from backup. If it is config file restore by copying 3rd system or reinstalling package.

    Appreciate your post.

  2. http://www.cgsecurity.org/wiki/PhotoRec

    PhotoRec is file data recovery software designed to recover lost files including video, documents and archives from Hard Disks and CDRom and lost pictures (thus, its ‘Photo Recovery’ name) from digital camera memory. PhotoRec ignores the filesystem and goes after the underlying data, so it will still work even if your media’s filesystem has been severely damaged or re-formatted.

    PhotoRec is free, this open source multi-platform application is distributed under GNU Public License. PhotoRec is a companion program to TestDisk, an app for recovering lost partitions on a wide variety of filesystems and making non-bootable disks bootable again. You can download them from this link.

    For more safety, PhotoRec uses read-only access to handle the drive or memory support you are about to recover lost data from. Important: As soon as a pic or file is accidentally deleted, or you discover any missing, do NOT save any more pics or files to that memory device or hard disk drive; otherwise you may overwrite your lost data. This means that even using PhotoRec, you must not choose to write the recovered files to the same partition they were stored on.
    PhotoRec runs under

    * DOS/Win9x
    * Windows NT 4/2000/XP/2003/Vista
    * Linux
    * FreeBSD, NetBSD, OpenBSD
    * Sun Solaris
    * Mac OS X

    and can be compiled on almost every Unix system.
    Photorec ignores the filesystem, this way it works even if the filesystem is severely damaged.

    It can recover lost files at least from

    * FAT,
    * NTFS,
    * EXT2/EXT3 filesystem
    * HFS+

    ReiserFS includes some special optimizations centered around tails, a name for files and end portions of files that are smaller than a filesystem block. In order to increase performance, ReiserFS is able to store files inside the b*tree leaf nodes themselves, rather than storing the data somewhere else on the disk and pointing to it. Unfortunately, PhotoRec isn’t able to deal with this, it’s why it doesn’t work well with ReiserFS.

  3. Hi all,

    I just had to recover a file from ext3 on Ubuntu, and used the utility ext3grep to do so.

    It’s in the Ubuntu repositories, so install it before you need it:
    sudo aptitude install ext3grep

    And remember, if you are storing your backups encrypted, keep the password to the encrypted folder in a file SEPARATELY (not in the encrypted folder), so when you delete it, you can just restore it, rather than get that ‘sinking feeling’…
    I was lucky, ext3grep worked for me – I had to follow the manual recovery examples on the ext3grep homepage, the auto recovery didn’t do it for me.

    Best of luck to you!

  4. This saved my life. Got a very important source code file back, 100%. Would have taken me days to rewrite. Didn’t delete a file, but server/samba failed, and stored a file of size 0 on top of the file. Have seen it before. Thank you.

  5. sir,
    how to recover the deleted files in linux in just 3 mints back, is this possible or not,
    i think that concerened file of deleted file is to tb store in may i think some other location, i think upto system boot it will be stored in sysytem, and after deleted files where it will be goes to

  6. Sir,
    we have used Red hat linux5 in my company…We have used php,mysql …
    Problem is some of the .php as well as txt files are to be deleted…
    how to recover that files..any 3rd party or free tool or recovery command is there…

    pls tell me very very urgent….pls help me

  7. By mistake I have run a command in CUI mode “rm -rf * text file”…and it deleted other files..
    Don’tr know which file have been deleted
    how can I check the deleted files?
    Is there any command to recover that?
    Kindly suggest…its urgent!!

  8. hi,
    i have mistakenly ran a comment “rm *” in the directory “/cust/scripts” which was having files of “.scr” extension. now i want to retrieve all the files. is there any way to retrieve the deleted files. pls help me out…..

  9. this may be the stupidest advice ever offered for such a common occurence of recoviering an accidental deletion – whoever posted this nonsense should be ostricized as the village-idiot he or she obviously is

  10. Ivan;

    This process would work fine for a small file that was deleted, like someone’s homework.

    It is not a substitute for a backup and recovery plan.

    If you would like a better plan, then make one. You could also dump on a daily the fs tree with the inodes table so that if you lose a file, at least you would know what blocks contain the data segments of your file to be able to recover it easier. That type of program is way beyond the scope of a simple one liner script as this shows.

    Grow up

  11. Hi All,

    I am using Redhat Linux 6, getting an error when users are able to login ‘-bash: /dev/null: permission denied’. Could you please help me in resolving. Only root is able to login. Also not able to use Vi editor.

  12. Sir,
    by mistake i run the commond rm -rf * on my server and all files are deleted ,
    can you please tell me the procedure how to recover all the data it’s very urgent for me and i am not able to logged in super user mode.
    Thank you in advance.

Leave a Comment