extundelete:Linux下基于开源的数据恢复工具(2)

中参数(options)有:
--version, -[vV],显示软件版本号。
--help,显示软件帮助信息。
--superblock,显示超级块信息。
--journal,显示日志信息。
--after dtime,时间参数,表示在某段时间之后被删的文件或目录。
--before dtime,时间参数,表示在某段时间之前被删的文件或目录。

动作(action)有:
--inode ino,显示节点“ino”的信息。
--block blk,显示数据块“blk”的信息。
--restore-inode ino[,ino,...],恢复命令参数,表示恢复节点“ino”的文件,恢复的文件会自动放在当前目录下的RESTORED_FILES文件夹中,使用节点编号作为扩展名。
--restore-file 'path',恢复命令参数,表示将恢复指定路径的文件,并把恢复的文件放在当前目录下的RECOVERED_FILES目录中。
--restore-files 'path',恢复命令参数,表示将恢复在路径中已列出的所有文件。
--restore-all,恢复命令参数,表示将尝试恢复所有目录和文件。
-j journal,表示从已经命名的文件中读取扩展日志。
-b blocknumber,表示使用之前备份的超级块来打开文件系统,一般用于查看现有超级块是不是当前所要的文件。
-B blocksize,表示使用数据块大小来打开文件系统,一般用于查看已经知道大小的文件。

1>fuser -k /dev/part  && umount /dev/被删除数据的盘  --杀掉访问磁盘的进程,umount 被删除数据的盘
  2>extundelete --inode 2  /dev/被删除数据的盘
  3>extundelete --restore-inode 13 /dev/被删除数据的盘
  4>恢复到 RECOVERD_FILES/
 
 
在数据被误删除后,第一时间要做的就是卸载被删除数据所在的分区,如果是根分区的数据遭到误删,
就需要将系统进入单用户模式,并且将根分区以只读模式挂载。这样做的原因很简单,因为将文件删除后,
仅仅是将文件的inode节点中的扇区指针清零,实际文件还储存在磁盘上,如果磁盘继续以读写模式挂载,
这些已删除的文件的数据块就可能被操作系统重新分配出去,在这些数据库被新的数据覆盖后,这些数据就真的丢失了,
恢复工具也无力回天。所以!以只读模式挂载磁盘可以尽量降低数据库中数据被覆盖的风险,以提高恢复数据成功的比例。

删除1.txt

方法1:通过inode恢复
查看删除文件在哪个分区上
root@dg extundelete-0.2.4]# df -h
文件系统      容量  已用  可用 已用%% 挂载点
/dev/sda2              44G  3.0G  39G  8% /
tmpfs                1004M  76K 1004M  1% /dev/shm
/dev/sda1            194M  51M  134M  28% /boot
# extundelete  /dev/sda4 --inode 2
mkdir test

extundelete  /dev/sda4  --restore-inode  8001  文件号

对比文件
diff /etc/passwd recover_file/file12
如果没有任何输出结果,说明两个文件完全一样

方法2:通过文件名称进行恢复
extundelete  /dev/sdb1 --restore-file passwd
会在当前目录下生成一个RECOVERED_FILES目录,里面保存已经恢复的文件

方法3:通过目录名称进行恢复
extundelete  /dev/sdb1 --restore-directory  /mongodb

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/15570.html