首页 > 其他分享 >磁盘爆满(df 与 du查看结果不一致导致)

磁盘爆满(df 与 du查看结果不一致导致)

时间:2022-09-02 09:55:50浏览次数:65  
标签:文件 查看 df 爆满 sh du lsof

记一次df -Th与du -sh空间大小不一致磁盘爆满问题的处理过程

原创 yuanfan2012 WalkingCloud 2022-08-21 08:05 发表于浙江 收录于合集 #Linux学习笔记270个 #CentOS7104个 #运维90个 #磁盘5个 #df2个

 

记一次df -Th与du -sh空间大小不一致磁盘爆满问题的处理过程

图片

问题场景:

在日常运维中,经常遇到磁盘空间满,发现占用磁盘空间大的文件已经被删除了,但df -Th查看磁盘空间还是满,没有释放出来 

但du -sh 查看时发现空间已经腾出来了

通常这种情况都是文件被删除,但是还被进程占用,造成du与df结果不一致。

du -sh * 和df -Th显示大小不一样,一般而言,df显示的使用空间要大于du

因为:当一个文件被删除的时候,在文件系统的目录中已经不可见了,所以du就不会再统计它了。

然而如果此时还有运行的进程持有这个已经被删除了的文件的句柄,那么这个文件就不会真正在磁盘中被删除,分区超级块中的信息也就不会更改。这样df仍旧会统计这个被删除了的文件。

查看方法:

lsof |grep delete

列出来的这些文件,表示已经删除,但实际上进程还在使用。

处理办法通常是停止占用文件的进程。

但是如果进程不能被停止呢?业务在使用,无法重启进程或服务 另一个处理办法就是通过清空文件释放空间。

处理办法如下:

通过lsof | grep deleted 找到未能删除掉的文件,确定占用的进程号;

#若没有lsof命令
yum install lsof -y
然后通过 ls -l /proc/PID/fd/* | grep 文件名,找到相应文件句柄;
清除文件内容 echo > /proc/PID/fd/FD_NUM

这个操作不会将文件删除,而是通过将文档内容清空的方法释放空间,文件还是存在的。

实践示例

问题现象:磁盘爆满由100%已经清理到91%,前面已有运维人员处理了,但是发现

1、问题现象截图

如下图所示 

图片

(图片可点击放大查看)

df -PTh查看/api目录占用85G 

但是du -sh /api目录只有35G

接手问题,通过百度搜索查证相关的解决方法后,开始进行处理

2、lsof |grep delete查看

lsof |grep delete

图片

(图片点击放大查看)

发现java进程id 28283 这个程序还占用这个catalina.2022-04-28.out文件未释放,文件大小约为50多G

与df -PTh和du -sh 的差值基本一致

3、不重启进程的处理过程

ls -l /proc/PID/fd/* | grep catalina
找到相应文件句柄,并使用echo > 方式清除
echo > /proc/28283/fd/1
echo > /proc/28283/fd/2

图片

(图片可点击放大查看)

这时再df -PTh查看可以看到已经与du -sh大小基本一致,问题解决

yuanfan2012

给小编加鸡腿!

标签:文件,查看,df,爆满,sh,du,lsof
From: https://www.cnblogs.com/cherishthepresent/p/16648758.html

相关文章

  • Nodejs安装karma 出现 Cannot find module 'optimist'错误
    http://www.javashuo.com/article/p-pnrbedet-dc.html原文   https://segmentfault.com/a/119000001188388安装好nodejs、配置好cnpm、以及自动化测试所需的karma......
  • 2022 HDU多校10
    WinnerPrediction(网络流)Problem\(n\)个人进行比赛,赢最多的人获胜,保证一定可以分出胜负,现在已知\(m_1\)场对决结果,还有\(m_2\)场对决结果未知,但知道比赛的两个人是谁,问......
  • 2022 HDU多校9
    ArithmeticSubsequence(二进制、思维、分治)Problem给定一个长度为\(n\)的序列,问是否可以对它重新排序使得重排后的序列中不存在等差子序列Solve如果一个数出现了\(3......
  • python读取PDF文件中的数据
    #-*-coding:utf-8-*-#模块的安装与导入由于pdfplumber和PyPDF2都属于第三方开源模块因此需要我们额外安装#安装pipinstallpdfplumber#pipinstallPyPDF2......
  • 关于使用命令行 cf login 登录 SAP BTP CloudFoundry 环境的问题
    在SAPBTP平台CloudFoundry环境找到APIendpoint:然后使用命令行cfapi,后面跟上这个APIendpoint:然后使用cflogin命令行登录:如果password输入错误,会遇到上......
  • 2022 HDU多校8
    Theramore(思维)Problem给定一个01串,可以进行无限次操作,每次操作可以把一个长度为奇数的区间翻转,问可以得到的字典序最小的01串是多少Solvehit1:反转后奇数位置还是在......
  • react 启动报错 ERROR in ./node_modules/fs-extra/lib/copy/copy-sync.js 5:13-28
    项目运行好好的,然后就报一堆错误起初我以为我安装了依赖倒置的问题,后来我只输出helloworld都出错。折腾两晚上。。。还是度娘帮了我Compiledwithproblems:XERROR......
  • 关于配置中科大的校园网络ustc-guest ustcnet eduroam的连接
    又是一年开学季,想到自己开学的时候经常搞不懂校园网的配置和连接(实际上过了一年多才搞清楚),于是写下这篇文档看看能不能帮到更多ustcers。目前的校园网大概有三类,一个是免......
  • apscheduler报警告The localize method is no longer necessary,as this time zone su
    PytzUsageWarning:Thelocalizemethodisnolongernecessary,asthistimezonesupportsthefoldattribute(PEP495).FormoredetailsonmigratingtoaPEP4......
  • Educational Codeforces Round 134 (Rated for Div. 2)
    DMaxiumAnd贪心,优先满足高位,每次判断是否能够满足这一位答案为1,如果能则更新答案,这样显然是优的EPrefixFunction模仿求前缀函数的算法,先预处理求出\(|S|\)的前缀函......