选择显示字体大小

浅谈linux文件系统反删除方法

作为一个多用户、多任务的操作系统linux下的文件一旦被删除,是难以恢复的。尽管删除命令只是在档节点中作删除标记,并不真正清除文件内容,但是其它用户和一些有写盘动作的进程会很快覆盖这些资料。不过,对于家庭单机使用的linux,或者误删档后及时补救,还是可以恢复的。

1、ext2文件系统结构的简单介绍

linux所用的ext2文件系统中,文件是以块为单位存储的,默认情况下每个块的大小是1k,不同的块以块号区分。每个档还有一个节点,节点中包含有档所有者,读写权限,文件类型等信息。对于一个小于12个块的档,在节点中直接存储档数据块的块号。如果档大于12个块,那么节点在12个块号之后存储一个间接块的块号,在这个间接块号所对应的块中,存储有256个档数据块的块号(ext2fs中每个块号占用4字节,这样一个块中所能存储的块号就是1024/4=256)。如果有更大的档,那么还会在节点中出现二级间接块和三级间接块。

2、恢复被误删档的方法

大多数linux发行版都提供一个debugfs工具,可以用来对ext2文件系统进行编辑操作。不过在使用这个工具之前,还有一些工作要做。

首先以只读方式重新挂载被误删的档所在分区。使用如下命令:(假设文件在/usr分区)

mount ?cr ?cn ?co remount /usr

-r表示只读方式挂载;-n表示不写入/etc/mtab,如果是恢复/etc上的档,就加上这个参数。如果系统说xxx partion busy,可以用fuser命令查看一下是哪些进程使用这个分区上的?n:

fuser ?cv ?cm /usr

如果没有什么重要的进程,用以下命令停掉它们:

fuser -k ?cv ?cm /usr

然后就可以重新挂载这些文件系统了。

如果是把所有的档统一安装在一个大的/分区当中,可以在boot提示符下用linux single进入单用户模式,尽量减少系统进程向硬盘写入资料的机会,要不干脆把硬盘挂在别的机器上。另外,恢复出来的资料不要写到/上面,避免破坏那些有用的资料。如果机器上有dos/windows,可以写到这些分区上面:

mount ?cr ?cn /dev/hda1 /mnt/had

然后就可以执行debugfs:(假设linux在 /dev/hda5)

#debugfs /dev/hda5

就会出现debugfs提示符debugfs:

使用lsdel命令可以列出很多被删除的文件的信息:

debugfs:lsdel

debugfs: 2692 deleted inodes found.

inode owner mode size blocks time deleted

164821 0 100600 8192 1/ 1 sun may 13 19:22:46 2001 …………………………………………………………………………………

36137 0 100644 4 1/ 1 tue apr 24 10:11:15 2001

196829 0 100644 149500 38/ 38 mon may 27 13:52:04 2001

debugfs:

列出的档有很多(这里找到2692个),第一字段是档节点号,第二字段是档所有者,第三字段是读写权限,接下来是档大小,占用块数,删除时间。然后就可以根据档大小和删除日期判断那些是我们需要的。比如我们要恢复节点是196829的文件:

可以先看看文件资料状态:

debugfs:stat <196829>

inode: 196829 type: regular mode: 0644 flags: 0x0 version: 1

user: 0 group: 0 size: 149500

file acl: 0 directory acl: 0

links: 0 blockcount: 38

fragment: address: 0 number: 0 size: 0

ctime: 0x31a9a574 -- mon may 27 13:52:04 2001

atime: 0x31a21dd1 -- tue may 21 20:47:29 2001

mtime: 0x313bf4d7 -- tue mar 5 08:01:27 2001

dtime: 0x31a9a574 -- mon may 27 13:52:04 2001

blocks:

594810 594811 594814 594815 594816 594817

………………………………….

total: 38

然后就可以用dump指令恢复文件:

debugfs:dump <196829> /mnt/hda/01.sav

这样就把档恢复出来了。退出debugfs:

debugfs:quit

另一种方法是手工编辑inode:

debugfs:mi <196829>

mode [0100644]

user id [0]

group id [0]

size [149500]

creation time [0x31a9a574]

modification time [0x31a9a574]

access time [0x31a21dd1]

deletion time [0x31a9a574] 0

link count [0] 1

block count [38]

file flags [0x0]

reserved1 [0]

file acl [0]

directory acl [0]

fragment address [0]

fragment number [0]

fragment size [0]

direct block #0 [594810]

…………………………….

triple indirect block [0]

使用mi指令后每次显示一行信息以供编辑,其它行可以直接按回车表示确认,把deletion time改成0(未删除),link count改成1。改好后退出debugfs:

debugfs:quit

然后用fsck检查/dev/hda5

fsck /dev/hda5

程序会说找到丢失的数据块,放在lost+found里面。这个目录里的文件就是我们要的。


 


关键字 本文所属关键字

相关 与本文相关文章

分类 所有文章关键字导航

源码编程相关

Java   Asp   PHP   .Net   XML   C/C++   CGI   VB   Jsp   J2ee   J2se   J2me   EJB   Servlet   Tomcat   Resin   Struts   Weblogic   Eclipse   ANT   GUI   JMS   Web servise   IDEA   Webphere   Hibernate   Spring   Jboss   Applet   Swing   Socket   Javamail   Perl   Ajax   P2P   安全   模式   框架   测试   开源   游戏

SQL数据库相关

My-SQL   Ms-SQL   Access   DB2   Oracle   Sybase   SQLserver   索引   存储过程   加密   数据库   分页   视图  

手机无线相关

3G   Wap   CDMA   GRPS   GSM   IVR   彩信   短信   无线   增值业务

网页设计制作相关

HTML   CSS   网页配色   网页特效   Javascript   VBscript   Dreamweaver   Frontpage   JS   Web   网站设计

网站建设推广相关

建站经验   网站优化   网站排名   推广   Alexa

操作系统/服务器相关

Windows XP   Windows 2000   Windows 2003   Windows Me   Windows 9.x   Linux   UNIX   注册表   操作系统   服务器   应用服务器

图形图像多媒体相关

Photoshop   Fireworks   Flash   Coreldraw   Illustrator   Freehand   Photoimpact   多媒体   图形图像

标准 网站致力的规范

Valid CSS!

无不良内容,无不良广告,无恶意代码

Valid XHTML 1.0 Transitional

creativecommons