在linux下使用debugfs恢复rm删除的文件

    原理主要是删除的文件并没有实际上从硬盘上摸去,只是inode索引删除了相关的信息,因此只要找到刚删除文件的block上,就可以恢复已经删除的文件。

    以下方法在ext3的文件系统上测试通过,ext2的没有测试过。假设删除的文件在dir下面,位于/dev/sda5上。

    主要借助debugfs

    1 运行debugfs,进入调度模式

    2 执行open /dev/sda5

    3 执行ls -d dir 会列出此目录最近的操作,其中可以看到<num>的日志删除记录

    4 执行logdump -i <num> 显示此日志内容

    5 在输出中寻找删除文件对应的block,记录下来blockid

    6退出debugfs,运行dd if=/dev/sda5 of=/tmp/saved  bs=1024 count=1 skip=blockid

    此时就把删除的文件恢复了,不过这个方法有个问题,如果删除的是大文件,则占用多个block,操作起来比较麻烦。

   debugfs在调试模式下,命令行比较难用,不过其支持-R选项,可以在SHELL里执行,就是用多个-R把要执行的命令连接起来,若命令中需要指定参数则需要加"",否则SHELL解析会有问题。

    比较好用的工具有testdisk,之前用过他来恢复和备份系统的分区表,没有恢复过文件。以后出问题也可以试试。

    http://www.cgsecurity.org/wiki/TestDisk_Download

  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
Linux中,debugfs是一个用于调试和恢复文件系统的工具。它可以用来修复或恢复由于文件系统损坏或其他问题而导致的目录丢失。 以下是使用debugfs恢复目录的基本步骤: 1. 首先,确保你具有root权限或者以root用户身份登录。 2. 卸载目标文件系统:使用umount命令卸载目标文件系统。例如,如果目标文件系统位于/dev/sda1上,可以使用以下命令卸载它: ``` umount /dev/sda1 ``` 3. 打开debugfs使用以下命令打开debugfs,并指定目标设备: ``` debugfs /dev/sda1 ``` 4. 使用ls命令查看文件系统中的目录结构。你应该能够看到所有的文件和目录。 5. 使用cd命令进入包含被删除目录的父目录。例如,如果目标目录的父目录是/lost+found,可以使用以下命令进入该目录: ``` cd /lost+found ``` 6. 使用mkdir命令创建一个新的目录。例如,如果你想恢复一个名为"recovered_directory"的目录,可以使用以下命令创建它: ``` mkdir recovered_directory ``` 7. 使用quit命令退出debugfs。 8. 挂载文件系统:使用mount命令重新挂载文件系统,让恢复的目录生效。例如,如果目标文件系统位于/dev/sda1上,可以使用以下命令重新挂载它: ``` mount /dev/sda1 /mnt ``` 现在,你应该能够在挂载的文件系统中看到恢复的目录。 请注意,使用debugfs进行文件系统恢复需要非常小心,并且需要对文件系统的结构和操作有一定的了解。确保在进行任何操作之前备份重要数据,并在不确定的情况下寻求专业人士的帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值