Linux 文件系统:恢复已删除文件的挑战
ahcoder 2025-04-08 11:10 67 浏览
天津鸿萌科贸发展有限公司从事数据安全服务二十余年,致力于为各领域客户提供专业的数据恢复、数据备份、数据取证、数据迁移解决方案,并针对企业面临的数据安全风险,提供专业的相关数据安全培训。
天津鸿萌科贸发展有限公司是众多国际主流数据取证及恢复软件的授权代理商:Miray(HDClone/HDShredder)、Passware、PassMark、ElcomSoft、R-Studio、Systools、GetData、Stellar、ReclaiMe、UFS 等。
如今,Linux 操作系统越来越受欢迎。它的明显优势首先是免费。此外,该操作系统提供了种类繁多的版本及其衍生产品,可满足从手机到超级计算机等设备的不同用户需求。
Linux 操作系统使用独有的文件系统,包括 Ext2、Ext3 和 Ext4、XFS、ReiserFS、JFS (JFS2) 等。Linux 文件系统的功能各不相同,每个系统都有特定的用途。在文件删除过程中,每个文件系统都以自己的方式运行,导致不同的恢复结果,有时甚至会失败。
Linux 操作系统中数据是如何组织的?
与大多数其他文件系统一样,Linux 文件系统使用块数据结构。在逻辑层面,数据存储以小数据单元 - 扇区 - 通常为 512 字节大小运行。可以将存储扇区想象为具有序号的单元格。在写入数据片段时,需要一个或多个这样的扇区。在读取存储驱动程序地址此扇区的数据。
为了优化磁盘寻址,文件系统将相等的扇区集组合成可在逻辑级别使用文件系统驱动程序寻址的块。最小可能的区块大小是一个扇区。大多数文件系统(包括 Linux 文件系统)都使用块作为最小的可寻址磁盘单元。通常,小于一个块的文件或其片段将占用整个块。但是,某些文件系统(如 ReiserFS)可能会使用块内的剩余空间来分配小文件和文件片段。
通常,存储上的数据是这样组织的:一个文件被分配到一个块中;如果文件的大小超过块,则文件系统会再提供一个块来分配文件(ReiserFS 等情况除外)。数据被写入空闲磁盘块,不被任何文件或元数据(文件系统的技术信息)使用。
可用空间和碎片
许多连续或并发的请求 'create file', 'append data', 'truncate data', 'delete file' 使文件系统上的可用空间变得碎片化。
上图显示了最简单的碎片示例。在写入文件 3 时,没有空间按顺序写入文件片段,因此同一文件的片段被分配到两个未链接的空闲块中。在实践中,大文件可能包含多达数百个未链接的数据片段,每个片段有几个块。
文件系统不会立即使用 'delete' 命令擦除文件的片段,而是将这些片段占据的位置标记为 free。新文件将这个地方视为可以免费占用。因此,除非被新文件覆盖,否则文件实际上仍然是可恢复的。
碎片是如何链接的?
文件系统使用描述文件的特殊代理 – 信息节点 (简称 – inode) – 来链接有关文件碎片的信息。此信息包括对象类型、大小、分配表/列表/树的描述。
读取 inode,文件系统可以确定对象的类型并决定进一步的作 – 读/写/处理。Object size 表示对象占用的块数。最后,对象分配提供有关数据块实际位置的信息。
对象分配数据按以下方式组织:这些数据的关键部分是指向数据块或块的连续片段的指针的数组、列表或 B 树。此信息的第一部分或根作为 inode 的一部分存储。
恢复问题
通常,Linux 文件系统会在文件删除后清理部分 inode 信息。它们用零填充有关对象大小、对象类型/模式和分配的信息,从而导致有关文件的所有信息丢失。我们假设上图中的文件 2 和 3 是没有标头的 RAW 加密文件,并且两者都占用了完整的块,并且都被删除了。因此,没有关于文件分配的信息,使得数据恢复软件无法检测文件 2 和文件 3 的边界。遗憾的是,在实践中,是情况愈发恶化的数据恢复操作对于 Linux 文件系统来说太常见了。这通常受大量文件碎片等因素的影响。
解决方案
幸运的是,数据恢复软件提供了一组恢复方法,但不能保证 100% 的结果。他们包括:
- 文件系统日志的分析。以前版本的文件描述符可能仍保留在日志中。
- 分析不完整的结构。该软件可以通过可能仍在磁盘上的未擦除的文件元数据片段来预测文件系统文件。
- 基于签名的搜索:软件搜索已知的文件片段,并对以下片段的内容进行假设。但恢复结果通常不会给出确切的文件大小,除非找到本身包含文件大小的文件名头。这种方法对于严重碎片化的情况是无能为力的。
- 统计片段分析:该软件根据数据分析的统计方法对片段链接进行假设。这种方法对同质文件(大多数 bmp 图片、一些档案等)有帮助,但对异源内容(如 CD/DVD 映像等)无能为力。
- 搜索丢失的文件系统结构:该软件查找丢失的文件系统结构,帮助确定丢失片段的布局。
如果您打算自己进行数据恢复,请准备好执行大量手动工作来分析未命名文件或文件片段,因为大多数数据恢复软件在从 Linux 文件系统恢复后通常会产生不完整的恢复。或者,您可以求助于专业且可靠的数据恢复公司,确保文件安全地得到恢复。
优秀的数据恢复软件通常具有强大的机制,比如按签名进行 IntelliRAWTM 搜索,允许用户识别文件类型和分析文件系统结构。使用高效的软件技术,能够以最少的工作量获得最好的恢复结果。
鸿萌从事数据恢复业务二十余年,同时是众多国际主流数据恢复软件的代理商,可以为用户提供专业的数据恢复服务以及推荐最具有性价比的软件产品。
相关推荐
- Java程序员必备的Linux命令速查表
-
Java程序员必备的Linux命令速查表在Java开发的世界里,Linux就像一位默默支持的幕后英雄。作为一名Java开发者,掌握一些基本的Linux命令,不仅能提高工作效率,还能让你在团队中显得格外...
- Linux 命令速查手册:这 30 个高频指令,拯救 90% 的运维小白!
-
在Linux系统的世界里,命令行是强大的武器。对于运维小白而言,掌握一些高频使用的Linux命令,能极大提升工作效率,轻松应对各种系统管理任务。今天,就为大家奉上精心整理的30个Linu...
- linux磁盘管理相关命令(linux磁盘管理常用命令)
-
磁盘的使用情况会直接影响系统的性能,因此我们经常会用到以下命令,主要围绕:fdisk:磁盘分区df:文件系统的磁盘空间占用情况du:文件目录的磁盘空间占用情况查看磁盘关系lsblk查看磁盘分区情况fd...
- 第四章 Linux常用shell命令-4.5.磁盘管理
-
主要介绍一下跟磁盘管理相关命令,有比较多的内容摘抄自网络,如有侵权,请及时联系我删除:显示目前在Linux系统上的文件系统磁盘使用情况统计:df创建和维护分区表的程序:fdisk将磁盘分区或镜像挂...
- Linux新手必备:20个高效命令轻松掌握!
-
Linux基本命令使用指南在现代计算机操作系统中,Linux因其开放性、灵活性和强大的功能,广泛应用于服务器和开发环境中。作为技术人员,掌握Linux的基本命令是非常重要的。在本文中,我们将重点介绍2...
- 每日必学Linux命令:ls命令(linux命令详解之ls命令)
-
ls命令是linux下最常用的命令。ls命令就是list的缩写缺省下ls用来打印出当前目录的清单如果ls指定其他目录那么就会显示指定目录里的文件及文件夹清单。通过ls命令不仅可以查看linux文件...
- Linux系统dev和proc目录详解(linux dev/sr0)
-
简介:Linux系统里的/dev和/proc目录那可是相当重要的系统文件。在Linux系统中,/dev目录专门用来存放设备文件。不光有设备文件,系统里还有好多特殊功能也是通过设备的形式...
- Linux切换目录之cd命令(linux切换指定目录)
-
1.基本概念1.1命令作用当我们在Linux系统上工作时,做得相当多的一项任务就是在不同的目录之间进行切换,这时就需要用到cd命令了。cd是"changedirectory"的首...
- Linux切换目录(cd命令)(linux如何切换到目录)
-
cd命令,是ChangeDirectory的缩写,用来切换工作目录。Linux命令按照来源方式,可分为两种,分别是Shell内置命令和外部命令。所谓Shell内置命令,就是Shel...
- MongoDB数据库的快速部署和启动(mongodb的使用教程)
-
一、Mongodb介绍常见数据库介绍关系数据库RDBMS设计表结构,通过SQL语句进行操作。连表关系常见的关系型数据库:mysqloracle(商业)DB2(IBM)sqlserver(微软...
- 5分钟学会网络服务搭建,飞凌i.MX9352 + Linux 6.1实战示例
-
在“万物互联”的技术浪潮下,网络服务已成为连接物理世界与数字世界的核心纽带,它不仅赋予了终端设备“开口说话”的能力,更构建了智能设备的开发范式。本文就将以飞凌嵌入式OK-MX9352-C开发板(搭载了...
- centos安装geoserver并配置开机启动
-
前提条件:服务器已经安装了java环境一、下载下载地址:http://geoserver.org/release/maintain/下载后文件名为:geoserver-2.19.3-bin.zip二、...
- 开机启动流程(开机流程图)
-
grubandbootCentos5,6的开机启动流程grubCentos7的开机启动流程Centos5,6的开机启动流程initrd/initramfs一般存储在/boot目录下,以.img...
- Linux cron服务概述(crontab服务)
-
cron是Linux/Unix系统中一个非常重要的后台服务(守护进程),用于在预定的时间间隔自动执行命令或脚本。它使得自动化重复性任务成为可能,例如日志清理、数据备份、系统维护等。1.cron...
- CentOS 8利用rc.local进行开机自启动的配置
-
CentOS8利用rc.local进行开机自启动的配置CentOS8linux系统是不建议使用rc.local进行开机自启动的,建议创建systemdservice。我们为了方便以后多一个配置...
- 一周热门
- 最近发表
- 标签列表
-
- linux 远程 (37)
- u盘 linux (32)
- linux 登录 (34)
- linux 路径 (33)
- linux 文件命令 (35)
- linux 是什么 (35)
- linux 界面 (34)
- 查看文件 linux (35)
- linux 语言 (33)
- linux代码 (32)
- linux 查看命令 (33)
- 关闭linux (34)
- root linux (33)
- 删除文件 linux (35)
- linux 主机 (34)
- linux与 (33)
- linux 函数 (35)
- linux .ssh (35)
- cpu linux (35)
- 查看linux 系统 (32)
- linux 防火墙 (33)
- linux 手机 (32)
- linux 镜像 (34)
- linux ip地址 (34)
- linux 用户查看 (33)