首页 游戏 软件 资讯 排行榜 专题
首页
系统平台
Linux怎么查看已删除但未释放的句柄 Linux磁盘空间虚假占用详解

Linux怎么查看已删除但未释放的句柄 Linux磁盘空间虚假占用详解

热心网友
91
转载
2026-04-25

Linux磁盘空间虚假占用详解:当df与du的结果“打架”时

想必不少运维同行都遇到过这个经典的“灵异事件”:df -h 明明白白告诉你磁盘使用率100%,可用空间为0,但用 du -sh / 把根目录从头到尾算一遍,却发现实际占用的空间远没那么多。这中间的差值去哪了?

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

根本原因是被进程占用的已删除文件,df统计文件系统级块使用量包含此类文件,du只遍历可见目录树故不计;可用sudo lsof +L1精准定位并重启对应服务释放空间。

linux怎么查看已删除但未释放的句柄 linux磁盘空间虚假占用详解

简单来说,就是文件虽然被“删除”了,但某个或某些进程还紧紧攥着它的句柄不放。空间实际上被内核“暂扣”着,并没有真正释放回文件系统。所以,在Linux的世界里,删除文件并不总是等同于立刻释放空间,关键得看还有谁在用它。

lsof +L1:定位“幽灵文件”的唯一可靠入口

遇到这种情况,很多人的第一反应是去搜 lsof | grep deleted。但这里有个坑:这个命令会误匹配那些路径里恰好包含“deleted”字样的正常文件,比如 /tmp/deleted_cache/ 目录下的东西。这显然不是我们想找的目标。

真正专业的做法,是使用专为“链接计数为0”文件设计的过滤器:lsof +L1。这个选项能精准抓出那些已经被 unlink() 系统调用从目录树中移除,但文件描述符(fd)仍被进程打开着的“幽灵文件”。

具体操作时,有几个命令变体很实用:

  • 全局扫描sudo lsof +L1(普通用户权限看不到其他用户的句柄,所以sudo是必须的)
  • 限定用户sudo lsof -u www-data +L1(如果你怀疑是某个特定用户,比如Web服务用户)
  • 限定挂载点(需谨慎)sudo lsof +D /var/log +L1(注意,+D 选项会递归扫描目录,开销较大,通常只用于像 /var/log 这样明确怀疑的目录)

命令输出的结果里,有几个字段是关键:PID(进程ID)、FD(文件描述符,如 5w 表示5号描述符且为写入模式)、SIZE/OFF(当前占用的字节数,直接反映了“空间黑洞”的大小),以及标记 (deleted)(必须有这个标记,否则就不是我们要找的目标)。

为什么df和du的结果会差一大截?

这得从两者的统计原理说起。df 命令汇报的是文件系统级别的数据块使用情况,它从超级块中读取信息,所有被分配出去但尚未释放的块(包括那些已被删除但句柄未关闭的文件所占用的块)都会被计算在内。

du 命令则是老老实实地遍历目录树,统计每个可见文件的大小。对于那些已经从目录树中消失、仅存在于内核文件表里的“已删除文件”,du 自然就“看”不到了。

所以,dfdu 的差值,大致就等于所有未被释放的句柄所对应的 SIZE/OFF 总和。有个快速估算总占用的命令可以参考:

sudo lsof +L1 2>/dev/null | awk '{sum += $7} END {printf "MB: %.0f\n", sum/1024/1024}'

如果这个差值达到了GB级别,那基本可以断定,是某个日志文件或者核心转储(dump)文件在后台疯狂增长,并且被某个进程持续写入。

需要提醒的是,在某些容器或chroot隔离环境下,lsof 的视角可能受限,不一定能看到全部的句柄。

释放空间时最常踩的三个坑

找到罪魁祸首的PID之后,是不是就该立刻 kill -9 了?且慢,冲动是魔鬼。先看清楚这个进程是什么来头:它是systemd管理的服务吗?杀掉它会不会有子进程继承文件描述符?它支持平滑重启(reload)吗?

这里有几个常见的操作误区:

  1. 别直接上 kill -9:像nginx、rsyslog、Ja va应用这类程序,可能在强制终止时还在刷写缓冲区,粗暴地杀掉会导致日志丢失或触发非正常的退出流程。
  2. 优先尝试信号重载:对于支持重载的进程,可以先发信号试试。例如,sudo kill -USR1 常用于nginx或logrotate风格的日志重切;sudo kill -HUP 则常用于rsyslog等进程的重启。
  3. 清空 /proc//fd/ 要极度小心:通过 echo "" > /proc/1234/fd/5 的方式确实可以截断文件内容,但文件描述符依然保持可写状态。对于一些应用(比如某些数据库),文件长度的突然变化可能导致程序出错。

说到底,最安全、最标准的释放方式永远是:先确认该进程属于哪个系统服务(比如通过 systemctl status 查看),然后执行 systemctl restart 来优雅地重启服务。硬杀(kill -9)这种手段,最好留给无主进程或纯粹的调试场景。

另一种“假满”:inode耗尽

有时候,系统报错“No space left on device”,但 df -h 一看,明明还有20%的剩余空间。这很可能不是空间问题,而是inode(索引节点)耗尽了。inode是文件系统的元数据,用来存储文件的属性信息。文件数量爆炸式增长(比如海量小文件)就会吃光inode。

这时,用 df -i 命令查看,如果 IUse% 这一列显示100%,那就得立刻着手清理小文件了。

如何定位inode消耗大户?可以试试这个命令组合,它能快速找出目录树下小文件最密集的区域:

find /var -xdev -type f | cut -d/ -f1-4 | sort | uniq -c | sort -nr | head -5

常见的inode“杀手”包括:/var/spool/postfix/maildrop/ 目录下堆积的待发邮件、/var/lib/docker/overlay2/ 里残留的悬空镜像层(dangling layer),以及某些应用临时目录下生成的大量空文件。

在清理之前,同样需要确认一下:这些海量小文件,是否也被某个进程打开后未关闭?前面提到的 lsof +L1 命令同样能暴露这类“已删除但fd仍持有”的空文件句柄。

真正棘手的情况,是那种既没有出现在 lsof +L1 列表里,df -i 也显示正常的案例。这大概率是因为容器内部的视角隔离——文件句柄被容器内的进程持有,在宿主机上用 lsof 看不到;或者,句柄被某些内核线程(如 kdump)持有,它们通常不可见。对于这类情况,就需要进入容器的命名空间(namespace)内部去排查,或者检查 /proc/mounts,看看是不是存在挂载覆盖导致了信息隐藏。

来源:https://www.php.cn/faq/2362008.html
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

相关攻略

aoc显示器怎么调最好亮度
电脑教程
aoc显示器怎么调最好亮度

AOC显示器的最佳亮度,究竟怎么调? 说到AOC显示器的最佳亮度,一个经过多家专业实验室反复验证的黄金区间是50到60。这个数值可不是随便定的,它是在标准办公室光照(300-500勒克斯)环境下测出来的,能在保证画面层次丰富、细节清晰的同时,最大程度地照顾你长时间盯着屏幕的眼睛舒适度。调节起来,其实

热心网友
04.25
poe交换机插网线有顺序吗
电脑教程
poe交换机插网线有顺序吗

POE交换机插网线有顺序吗? 先说一个核心结论:给POE交换机插网线,物理端口顺序可以随意,但网线内部的“秩序”绝不能乱。这里的关键,在于网线本身必须严格按照T568A或T568B标准来制作,并且全程得用8芯全通、无氧铜材质的超五类及以上规格网线。为什么这么讲究?依据在于国际通行的IEEE 802

热心网友
04.25
如何使用SQL存储过程封装函数_统一业务逻辑提升复用性
数据库
如何使用SQL存储过程封装函数_统一业务逻辑提升复用性

SQL存储过程与函数:复用逻辑的正确打开方式 开门见山,先说一个核心判断:试图用SQL存储过程去直接“封装”函数,这条路基本走不通。 原因很简单,存储过程和标量函数、表值函数,从设计定位、语法结构到调用方式,完全是两套不同的体系。如果目标是为了复用业务逻辑,第一步不是强行封装,而是先搞清楚:什么场景

热心网友
04.25
SQL如何处理嵌套查询中的重复列名冲突_使用别名规范化
数据库
SQL如何处理嵌套查询中的重复列名冲突_使用别名规范化

SQL子查询的“列名冲突”与别名规范:从报错到根治 在编写SQL时,子查询是构建复杂逻辑的利器,但稍不注意,就可能掉进“列名不明确”的坑里。核心问题往往出在上下文隔离上:外层查询无法识别子查询内部的字段来源,一旦出现重名列,数据库引擎就“懵了”。要解决这个问题,关键在于显式指定字段、规范使用别名,并

热心网友
04.25
SQL如何计算移动平均值_使用ROWS BETWEEN窗口定义
数据库
SQL如何计算移动平均值_使用ROWS BETWEEN窗口定义

SQL移动平均必须用ROWS BETWEEN而非RANGE,因RANGE按值分组遇重复值会导致窗口边界漂移,而ROWS严格按物理行数滑动,确保“最近N条”的准确平均;如7日均值需ROWS BETWEEN 6 PRECEDING AND CURRENT ROW。 SQL移动平均为什么必须用ROWS B

热心网友
04.25

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

《异环》六大保险点位分享
游戏攻略
《异环》六大保险点位分享

《异环》六大保险点位分享:轻松入手海量方斯 在《异环》的世界里探索,手头紧可不行。好消息是,地图上藏着一些“大保险”,打开就能获得海量的游戏货币——方斯。这无疑是快速积累前期资本、提升游戏体验的捷径。今天,我们就来详细盘点一下由“一世逍遥”发现的六大保险点位,帮你把资源稳稳收入囊中。 以上便是目前整

热心网友
04.25
异环共存测试什么时候开启
游戏攻略
异环共存测试什么时候开启

异环共存测试:开启技术协同新篇章的关键一步 在科技前沿领域,异环共存测试正逐渐从理论构想走向实践舞台,成为推动相关技术从实验室走向规模化应用不可或缺的一环。它的意义,远不止于一次简单的技术验证。 测试启动在即:万事俱备,只待东风 那么,这项备受瞩目的测试究竟何时会正式启动?这无疑是圈内人士共同关注的

热心网友
04.25
免费行情软件网站app官方版 币圈行情网站app推荐
web3.0
免费行情软件网站app官方版 币圈行情网站app推荐

对于加密货币投资者而言,及时获取准确的行情数据至关重要 想在币圈做出明智的决策,手里没几件趁手的“兵器”可不行。今天,我们就来盘点几款市场上广受好评的免费行情工具,从交易所App到专业数据平台,它们各有所长,能帮你把市场脉搏摸得更准。 主流交易所App(行情与交易一体) 对于大多数投资者来说,交易所

热心网友
04.25
明日方舟贝洛内是否值得培养
游戏攻略
明日方舟贝洛内是否值得培养

在明日方舟的众多角色中,贝洛内是一位颇具特色的干员,其是否值得培养引发了不少玩家的讨论。 贝洛内的技能机制,可以说是她最亮眼的招牌。一技能“强化下次攻击”,听起来简单,实战中却颇有讲究。面对那些皮糙肉厚的敌人,这一下高额伤害往往能起到关键的破防作用,为后续输出打开局面。而她的二技能就更具战术价值了,

热心网友
04.25
如何退出weverse加入的社区
游戏攻略
如何退出weverse加入的社区

如何退出Weverse社区?一份详细的操作指南 在Weverse上,随着兴趣变化或时间安排调整,你可能需要退出一些已加入的社区。这个过程其实并不复杂,但了解清楚每一步,能帮你避免误操作。下面就来详细拆解一下整个流程。 第一步:定位并进入目标社区 首先,确保你已经登录了自己的Weverse账号。打开应

热心网友
04.25