zoukankan      html  css  js  c++  java
  • Linux学习之CentOS(十八)-----恢复Ext3下被删除的文件与 使用grep恢复被删文件内容(转)

    前言

    下面是这个教程将教你如何在Ext3的文件系统中恢复被rm掉的文件。

     删除文件

    假设我们有一个文件名叫 ‘test.txt’

      $ls -il test.txt

     15 -rw-rw-r– 2 root root 20 Apr 17 12:08 test.txt

    注意:: “-il” 选项表示显示文件的i-node号(15),如果你不知道Unix/Linux文件系统的“I结点”的话,你有必要先补充一下相关的知识。简单说来,i结点就是操作管理文件的一个标识号。

    我们再看一下其内容:

    $ cat test.txt
    this is test file

    好,现在我们开始删除文件:

    $rm test.txt
    rm: remove write-protected regular file `test.txt’? y

     使用 Journal 和 Inode 号恢复

    注意,如果你删除文件后重启了系统,那么,相关的文件 journal 会丢失,我们也就无法恢复文件了。所以,恢复文件的前提是,Journal不能丢失,即,系统不能重启。

    因为我们已经知道 test.txt 文件的 inode 号是 15,所以我们可以使用 debugfs 命令来查看:

    复制代码
    debugfs: logdump -i <15>
    FS block 1006 logged at sequence 404351, journal block 7241
    (inode block for inode 15):
    Inode: 15 Type: regular Mode: 0664 Flags: 0×0 Generation: 0
    User: 0 Group: 0 Size: 20
    File ACL: 0 Directory ACL: 0
    Links: 1 Blockcount: 8
    Fragment: Address: 0 Number: 0 Size: 0
    ctime: 0x48159f2d — Mon Apr 28 15:25:57 2008
    atime: 0x48159f27 — Mon Apr 28 15:25:51 2008
    mtime: 0x4806f070 — Thu Apr 17 12:08:40 2008
    Blocks: (0+1): 10234
    No magic number at block 7247: end of journal.
    复制代码

     请注意上面信息中的这一行:

    Blocks: (0+1): 10234

    这就是inode 15存放文件的地址(数据块)。然后,我们知道了这个地址,我们就可以使用 dd 命令,把这个地址上的数据给取出来。

    复制代码
    #dd if=/dev/sda5 of=/tmp/test.txt bs=4096 count=1 skip= 10234
    1+0 records in
    1+0 records out
    if 是输入的设备
    of 是输出的设备.
    bs 指定一个block的大小
    count 说明有多少个block需要dump
    skip 说明从开始的地方跳过 10234 个block,并从取下一个block的数据
    复制代码

     下面让我们看一下被恢复的文件:

    $cat /tmp/test.txt 
    this is test file

    当然,上面的文件恢复是基于我们知道文件的inode,可在现实中,我们并不知道这个信息,如果我们不知道inode,我们还可能恢复吗?是的,这是可能的,让我们来看一下如何恢复。

     使用 Journal 和 文件名恢复

    如果我们不知道文件的inode我们可能恢复吗?我可以告诉你,这是不可能的事情。不过我们有办法知道文件的inode号。下面让我们来看看怎么做到:

    $rm mytest.txt
    rm: remove write-protected regular file `mytest.txt’? y

    注意,我们并不知道其inode号,但我们可以使用 debugfs 命令来查看(使用其 ls -d 选项)。

    debugfs:  ls -d
     2  (12) .    2  (12) ..    11  (20) lost+found    2347777  (20) oss
    <2121567> (20) mytest.txt

    你看文件名了吧,它的inode号是 <2121567> ,注意,被删除了的文件的inode都是用尖括号包起来的。

    即然知道了inode号,那么我们就很容易恢复了(使用 logdump选项):

    复制代码
    debugfs:  logdump -i <2121567>
    Inode 2121567 is at group 65, block 2129985, offset 3840
    Journal starts at block 1, transaction 405642
      FS block 2129985 logged at sequence 405644, journal block 9
        (inode block for inode 2121567):
        Inode: 2121567   Type: bad type        Mode:  0000   Flags: 0×0   Generation: 0
        User:     0   Group:     0   Size: 0
        File ACL: 0    Directory ACL: 0
        Links: 0   Blockcount: 0
        Fragment:  Address: 0    Number: 0    Size: 0
        ctime: 0×00000000 — Thu Jan  1 05:30:00 1970
        atime: 0×00000000 — Thu Jan  1 05:30:00 1970
        mtime: 0×00000000 — Thu Jan  1 05:30:00 1970
        Blocks:
      FS block 2129985 logged at sequence 405648, journal block 64
        (inode block for inode 2121567):
        Inode: 2121567   Type: regular        Mode:  0664   Flags: 0×0   Generation: 913772093
        User:   100   Group:     0   Size: 31
        File ACL: 2130943    Directory ACL: 0
        Links: 1   Blockcount: 16
        Fragment:  Address: 0    Number: 0    Size: 0
        ctime: 0x4821d5d0 — Wed May  7 21:46:16 2008
        atime: 0x4821d8be — Wed May  7 21:58:46 2008
        mtime: 0x4821d5d0 — Wed May  7 21:46:16 2008
        Blocks:  (0+1): 2142216
    复制代码

    上面有很多信息,让我们仔细地查看,你可以看到下面一行信息:

    FS block 2129985 logged at sequence 405644, journal block 9

    并且,其类型是:

     Type: bad type 

    再仔细看一下文件的时间戳下面的Blocks: 什么也没有。那么,让我们看一下下一个block:

    FS block 2129985 logged at sequence 405648, journal block 64
        (inode block for inode 2121567):

    这一条Journal就有block信息了:

    Blocks:  (0+1): 2142216

    这就是被删除文件的地址,让我们再次运行恢复命令:

    $sudo dd if=/dev/sda5 of=/home/hchen/mytest_recovered.txt bs=4096 skip=2142216 count=1

    再让我们来检查一下文件内容:

    $ cat mytest_recovered.txt
    this is my test file 

     小结

    好了,下面是我们的一些总结:
    1)使用 debugfs: ls -d 找到被删除文件的inode号。
    2)使用 debugfs:logdump找到文件的数据块地址。
    3)使用dd 命令把数据取出来存成文件。

    网上有很其它不同的方法来恢复文件,基本上也是使用debugfs这个命令,有的还使用到了lsdel,其实大同小异,这个教程是我在网上看到的,虽然他说只是针对Ext3文件系统的,但我总感觉应该可以用于Ext2文件系统,不过我没有试过。也许Ext2和Ext3被debugfs输出的信息不一样吧。大家可以去试试。

     转自 http://coolshell.cn/articles/1265.html#more-1265

    使用grep恢复被删文件内容(转)

    在Unix/Linux下,最危险的命令恐怕就属rm命令了,每次在root下使用这个命令的时候,我都要盯着命令行看上几分钟才敢把回车敲下去。

    以前,看到同事在脚本中使用rm命令 —— rm {$App_Dir}/* 。因为脚本没有判断变量$App_Dir是否为空,结果,在一次用root操作的时候,整个操作系统一下就不见了,还好只是开发机。从此,我们大家都再也不敢使用rm命令了。

    这里给大家介绍一个小技巧用来恢复一些被rm了的文件中的数据。我们知道,rm命令其实并不是真正的从物理上删除文件内容,只过不把文件的inode回收了,其实文件内容还在硬盘上。

    所以,如果你不小删除了什么比较重要的程序配置文件的时候,我们完全可以用grep命令在恢复,下面是一个恢复示例:

    grep -a -B 50 -A 60 'some string in the file' /dev/sda1 > results.txt

    说明:

    • 关于grep的-a意为–binary-files=text,也就是把二进制文件当作文本文件。
    • -B和-A的选项就是这段字符串之前几行和之后几行。
    • /dev/sda1,就是硬盘设备,
    • > results.txt,就是把结果重定向到results.txt文件中。

    如果你幸运的话,你就可以看到被恢复的内容了。

  • 相关阅读:
    Java中使用Oracle的客户端 load data和sqlldr命令执行数据导入到数据库中
    迁移mysql数据到oracle上
    SQL Developer 警告--无法安装某些模块
    Oracle SQLDeveloper ORA-01017 invalid username/password;logon denied (密码丢失解决方案)
    解决Java连接MySQL存储过程返回参数值为乱码问题
    Tensorflow BatchNormalization详解:2_使用tf.layers高级函数来构建神经网络
    Tensorflow BatchNormalization详解:1_原理及细节
    随机切分csv训练集和测试集
    tf.session.run()单函数运行和多函数运行区别
    tf.train.batch的偶尔乱序问题
  • 原文地址:https://www.cnblogs.com/qzqdy/p/8042051.html
Copyright © 2011-2022 走看看