0

0

Linux 查不到文件大小变化?带你排查原因

冷炫風刃

冷炫風刃

发布时间:2025-12-04 18:34:02

|

912人浏览过

|

来源于php中文网

原创

文件大小未变化可能因缓存、句柄未释放、只读挂载等导致。1. 页缓存未刷入:用sync刷新后查看;2. 文件被删除但句柄保留:lsof查deleted条目;3. 文件系统只读:mount检查ro选项并尝试remount,rw;4. 稀疏或压缩文件:对比ls与du结果;5. 命令误用:确认路径、链接及高频监控变化。

linux 查不到文件大小变化?带你排查原因

Linux 上查不到文件大小变化,可能是由于多种原因导致的。表面上看文件似乎没变,但实际可能已有写入操作。下面带你一步步排查常见原因和对应的解决方法

1. 文件已被其他进程打开并缓存

Linux 使用页缓存(page cache)机制提升 I/O 性能。当一个文件被进程打开后,写入内容可能暂存在内存中,还未真正刷入磁盘。此时用 ls -l 查看到的大小可能是旧值。

检查方法:

  • 使用 lsof +L FILENAME 查看文件是否被某个进程锁定或重定向。
  • lsof FILENAME 看是否有进程正在写入该文件。
  • 查看内核是否已将数据写回磁盘:执行 sync 强制刷新缓存,再运行 ls -l 看大小是否更新。

2. 文件被截断或清空但句柄未释放

常见于日志轮转(log rotation)。例如 logrotate 删除原文件并新建同名文件,但原有进程仍持有旧文件句柄继续写入。此时你查的是新文件(大小为0),而数据实际写进“看不见”的已删除文件中。

判断方式:

  • 运行 lsof | grep deleted,若看到类似 “/var/log/app.log (deleted)” 的条目,说明进程仍在写一个已被删除的文件。
  • 该文件的实际大小可通过 lsof 输出中的 SIZE 列查看。
  • 重启对应服务可释放句柄,使写入切换到新文件。

3. 文件系统挂载问题或只读模式

如果文件系统因错误进入只读状态,写入会失败,文件大小自然不会变。

排查步骤:

千问APP
千问APP

阿里最强大模型官方AI助手

下载
  • 运行 mount | grep $(df . | tail -1 | awk '{print $1}') 查看当前挂载选项,确认是否含 ro(只读)。
  • 检查系统日志:dmesg | grep -i errorjournalctl -k 看是否有 I/O 或文件系统错误。
  • 尝试重新挂载为读写:mount -o remount,rw /dev/sdXN /mount/point(需 root)。

4. 使用了稀疏文件或压缩文件系统

某些场景下,文件显示大小与实际占用空间不一致。例如稀疏文件中写入大量零,文件逻辑大小增加,但磁盘占用(block)不变。

查看真实情况:

  • 对比 ls -l FILEdu FILE。若 ls 显示 1G,du 显示几 KB,说明是稀疏文件。
  • 使用 du --apparent-size FILE 可查看逻辑大小。
  • 在 Btrfs、ZFS 等压缩文件系统上,数据写入后可能被压缩,du 显示值偏小也属正常。

5. 工具本身使用不当

有时不是系统问题,而是命令用法不对。

注意点:

  • 确保你在查看正确的路径:pwdrealpath FILE 避免误判。
  • 符号链接会影响结果,用 ls -la 确认是否链接到其他位置。
  • 定时任务或脚本可能每秒写入又清空,建议用 watch -n 0.1 'ls -l FILE' 高频监控变化。

基本上就这些。从进程占用、文件状态、文件系统特性到命令使用,逐层排查,通常能定位到原因。关键是理解 Linux 中“文件”不仅是磁盘上的数据,还涉及句柄、缓存和挂载机制。不复杂,但容易忽略细节。

相关专题

更多
python中print函数的用法
python中print函数的用法

python中print函数的语法是“print(value1, value2, ..., sep=' ', end=' ', file=sys.stdout, flush=False)”。本专题为大家提供print相关的文章、下载、课程内容,供大家免费下载体验。

185

2023.09.27

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

187

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

288

2023.10.25

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1349

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

703

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

294

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

776

2023.07.05

linux系统安装教程
linux系统安装教程

linux系统是一种可以免费使用,自由传播,多用户、多任务、多线程、多CPU的操作系统。本专题提供linux系统安装教程相关的文章,大家可以免费体验。

572

2023.07.06

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

3

2026.01.19

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.4万人学习

Git 教程
Git 教程

共21课时 | 2.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号