- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我在处理一个大型项目时遇到了一个非常奇怪的问题。我在一个分区上写了一堆相同大小的文件(尝试了 RAM 磁盘和通过 diskmgmt.msc
创建的虚拟磁盘)。当没有足够的可用空间来容纳另一个文件时(如 GetDiskFreeSpaceExW
所报告),我删除了一个(只有一个) 以前创建的文件并写入新文件。然后,我删除另一个旧文件并写入一个新文件,无限循环(因此,您可以将分区视为大小相同的文件的环形缓冲区)。在一系列的写入-删除(从几百到几千)之后,我在写入新文件时遇到了 no free space
错误(在此之前,GetDiskFreeSpaceExW
报告足够的空间)。我请我的几位同事尝试在他们的硬件上重现该问题,但问题没有再次出现。
为了澄清一些事情,这里是确切的算法:
重要的是要注意,我将数据写入大小为 4096 字节的 block 中的文件(问题可能会或可能不会重新出现,具体取决于 block 大小)。文件大小为 5MB。 NTFS 分区大小为 21 MiB。簇大小为 512 B(同样,更改这些参数会影响结果)。使用这些参数,在创建第 684 个文件时会发生故障。这不取决于我使用的是 RAM 磁盘还是虚拟磁盘(因此,这不是特定实现的问题)。
我分析了故障后生成的磁盘镜像转储,发现文件碎片化严重。 Chkdsk 报告在实验之前和之后都没有问题。在系统日志中没有发现错误。
我的上网本(Dell Inspiron 1110)的可能相关参数:
有没有人知道发生了什么以及如何调试它?我在哪里可以找到更多信息?我已经没有想法了,我需要尽快解决这个问题......
UPD:问题发生在我写入文件数据时(即 write()
失败),不是我创建文件时.所以,看起来我并不缺少 MFT 条目。
UPD2:回答了一些被问到的问题
最佳答案
很好的 NTFS 问题,这里没有所有信息。什么是目录结构?有关于此的任何 LINK 文件吗?您是否在驱动器上使用压缩?卷影副本?
您不会用完 MFT 空间,因为文件/目录的数量是恒定的。这意味着 MFT 是静态的。此外,MFT 保留空间将用于磁盘空间不足的情况。我已经用完了 NTFS 卷上的每个簇。
对于正在发生的事情有几种解释:
1) $Log 文件可能已经增大。这是回滚日志。
2) 如果驱动器上的权限不统一,则用于文件安全信息的@SII 文件可能会增长
3) 如果该卷上的某些文件有指向它们的 .lnk/快捷方式文件,系统会将每个目标的 GUID 放入索引中。 (如果您在资源管理器中双击某个文件,您将获得 .lnk 文件 - 在最近的文档中!)
4) 目录结构不是静态的(或者文件名的长度不统一)目录的 $index 缓冲区的大小可能会增加。
5) 如果您在该驱动器上有一个系统卷目录,您可能有卷影副本和其他操作系统特定数据。
6) 备用数据流未显示在文件大小中。有没有?
7) TxF - 在 vista 和更高版本下,可能存在占用变量空间的事务层。
8) 坏簇?集群可能会变坏(但 chkdsk 可能会注意到这一点 ..)
9) 文件变得碎片化,碎片列表与其他元数据一起太大而无法放入 MFT 记录(不太可能,因为你的文件很小而且你没有非常长的文件)
10) 硬链接(hard link)的使用也将更多数据放在驱动器上。
我已经列出所有这些作为其他人的引用!
最后的说明 - 有时你可以创建和写入一个小文件,即使有 0 个空闲字节,因为 NTFS 驻留文件只占用一个 MFT 记录(它们会恢复一个已删除的空闲记录)
关于c - 创建/删除一系列相同大小的文件后 NTFS 磁盘空间不足,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3565770/
所以我正在为考试复习,并在 SQL 河(或荒地)中撞到了一块大石头 我制作了以下表格并插入了以下数据: create table Permissions ( fileName VARCHAR(
我有一个使用 maxWidth 定义的 jqueryui 对话框。 $("#myDialog").dialog({ autoOpen: false, width: 'a
注意:我遗漏了不相关的代码 所以我目前正在研究 CCC 1996 P1,这个问题的全部目的是能够计算一个整数输入是完美数、不足数还是充数。我上面列出的代码可以工作,但是我认为它太慢了。该代码会迭代每个
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
我正在使用 Go 和 Redis 开发 API。问题是RAM使用不足,我找不到问题的根源。 TL;DR 版本 有数百/数千个哈希对象。每个 1 KB 的对象(键+值)占用大约 0.5 MB 的 RAM
在我的 GCE Kubernetes 集群上,我无法再创建 pod。 Warning FailedScheduling pod (www.caveconditions.com-f1be467e3
当我尝试在EKS Fargate群集上安装指标服务器时,它抛出错误: 0/4 nodes are available: 4 Insufficient pods. 按照以下说明从此处安装指标服务器:ht
遍布this document Apple 提到 iOS 在某些情况下会终止应用程序,最常见的原因似乎是释放一些 RAM。这会导致未实现状态恢复的应用程序出现问题——用户正在处理和暂时离开的一些内容可
尝试处理一个10分钟的音频文件时出现以下错误。我刚刚开始使用Google Cloud产品,所以我是唯一访问此资源的人。我怎么可能超出配额?配额设置为其默认值,我认为我没有任何限制。还有其他原因吗? 我
R 语言让我感到困惑。实体有模式和类,但即使这样也不足以完全描述实体。 这个answer说 In R every 'object' has a mode and a class. 所以我做了这些实验:
我在 west-1 有一个 Openshift v3 项目。在其中,我有一个运行良好的应用程序,但在 GitHub 提交代码中非常下游的内容后,该应用程序停止工作。问题在于制作 pod: No nod
我在 west-1 有一个 Openshift v3 项目。在其中,我有一个运行良好的应用程序,但在 GitHub 提交代码中非常下游的内容后,该应用程序停止工作。问题在于制作 pod: No nod
在 how-do-i-access-the-stackoverflow-api-from-mathematica我概述了如何使用 SO API 让 Mathematica 制作一些有趣的顶级回答者声誉
所以在 GKE 上,我有一个 Node.js app,每个 pod 使用大约:CPU(cores): 5m, MEMORY: 100Mi 但是我只能为每个 Node 部署 1 个 pod。我使用的是
我正在使用 async.eachOfSeries 超过 300 个数组并请求一些 GA api,它工作正常但有时我会收到错误.. UnhandledPromiseRejectionWarning:错误
我正在尝试在 AWS ec2 上托管的 kubernetes 集群上使用 mr3 设置配置单元。当我运行命令 run-hive.sh 时,Hive 服务器启动,并且 master-DAg 被初始化,但
创建订阅时有时会出现以下错误: Insufficient tokens for quota 'administrator' and limit 'CLIENT_PROJECT-100s' of ser
我是一名优秀的程序员,十分优秀!