cd / df -h Filesystem Size Used Avail Use% Mounted on /dev/md2 25G 24G 0 100% /
但是根文件夹下显示所有文件夹(比如 usr 、var 、tmp 等文件夹)大小之和为 10G ,根本没用到 24G
删了一个 2G 的日志文件,有趣的来了,根文件夹所有文件夹大小之和变为 8G ,Avail 立马变为 2G ,然后 1.8G ,1.6G ,1.5G......不断缩小,直至为 0 。但根文件夹所有大小之和还是 8G
这是怎么造成的?怎么排查?
1 angryPHP 2022-12-27 11:58:43 +08:00 du 命令 |
![]() | 3 yinheli 2022-12-27 12:05:54 +08:00 ![]() lsof -nP | grep 'deleted' |
![]() | 4 yinheli 2022-12-27 12:06:14 +08:00 看看有没有删掉的,但是句柄还在的文件 |
![]() | 5 aaa5838769 2022-12-27 12:06:26 +08:00 用 du 命令 从根目录开始往下找到是那个目录占用最大。 |
![]() | 6 chrawsl 2022-12-27 12:06:31 +08:00 du / -h -d1 -d1 代表递归深度 |
![]() | 7 47jm9ozp 2022-12-27 12:09:33 +08:00 ![]() ncdu |
![]() | 8 kisshere OP |
![]() | 9 idblife 2022-12-27 12:20:30 +08:00 yum install ncdu 不用谢 |
10 zzfra 2022-12-27 12:23:22 +08:00 我不负责地猜测一下,docker 导致的问题 |
![]() | 11 AoEiuV020CN 2022-12-27 12:26:39 +08:00 发现 Avail 在变小就应该马上切 u 盘系统再考虑怎么排查, |
![]() | 12 css3 2022-12-27 12:32:54 +08:00 看下回收站是否清空 |
![]() | 13 nbweb 2022-12-27 12:35:40 +08:00 via Android 先把 md2 umount 了再看看容量。 |
14 troilus 2022-12-27 12:38:12 +08:00 大概率是 docker ,前几天同样问题 |
16 Dragonish3600 2022-12-27 12:54:25 +08:00 via iPhone reboot first |
![]() | 17 xyjincan 2022-12-27 13:07:58 +08:00 删除没有关闭的文件,重启系统 or 进程就好了 建议使用 echo > xxx.log 删除日志文件 |
![]() | 18 defunct9 2022-12-27 13:12:37 +08:00 lsof +L1 |
![]() | 19 villivateur 2022-12-27 13:17:03 +08:00 ![]() @defunct9 这次居然没让开 ssh ? |
![]() | 20 dd991 2022-12-27 13:17:06 +08:00 temp 文件夹 |
![]() | 21 limbo0 2022-12-27 13:30:07 +08:00 du -sh -- * | sort -rh |
22 Jirajine 2022-12-27 13:35:22 +08:00 下个 gdu 看看 |
![]() | 23 gamexg 2022-12-27 13:42:56 +08:00 linux 下正在打开的文件也可以删除,但是这个删除只是 ls 不显示,实际这个文件还是存在,并且占用空间。直到使用这个文件程序释放这个文件,文件才被真的删除,空间才会被释放。 所以最简单的办法,重启下再看空间占用。 |
![]() | 24 labnotok 2022-12-27 13:45:12 +08:00 via Android ncdu -x |
![]() | 25 McreeWu 2022-12-27 13:50:35 +08:00 一般是 deleted 文件导致的,如果找不到的话可以看看磁盘预留空间 |
![]() | 26 wjx0912 2022-12-27 13:53:16 +08:00 github search: ncdu |
27 V2April 2022-12-27 13:58:40 +08:00 我遇到过一次这个,是 onlyoffice 的日志文件 |
![]() | 28 stephenyin 2022-12-27 14:05:07 +08:00 找 /home/xxx 下大于 500M 的文件:find /home/xxx -size +500m -name -type f |
![]() | 29 stephenyin 2022-12-27 14:05:41 +08:00 @stephenyin #28 find /home/xxx -size +500m -type f |
![]() | 30 stephenyin 2022-12-27 14:07:14 +08:00 @stephenyin #29 find /home/xxx -size +500M -type f |
![]() | 31 DingJZ 2022-12-27 14:29:49 +08:00 遇到过一次 Inodes 的问题,df -i 查看 Inodes 占用,如果是的话清 /tmp |
32 julyclyde 2022-12-27 15:01:58 +08:00 这么经典的故障 丢失的空间可能都是类似于你“删除了一个日志”这类操作导致的 |
![]() | 33 pingpp00 2022-12-27 15:24:04 +08:00 在根目录下执行 du -shx * ,然后依次排查 |
![]() | 34 QKgf555H87Fp0cth 2022-12-27 15:43:43 +08:00 sudo du -hsx * | sort -rh |
35 gam2046 2022-12-27 15:46:51 +08:00 是某个应用占用了个大文件,但是你已经通过 rm 把这个文件删掉,同时程序并未释放此文件的句柄,所以会造成你这种情况。因为句柄被占用,文件在内核中并未真正释放。 如果记得是哪个程序占用的大文件,重启这个程序即可。 如果不记得是哪个程序,重启系统即可。 |
![]() | 36 JohnBull 2022-12-27 15:58:11 +08:00 肯定是有个超大的匿名文件 |
![]() | 37 zooo 2022-12-27 16:09:55 +08:00 ncdu 确实好用些 |
39 xwayway 2022-12-28 11:14:55 +08:00 楼上各位大哥说得都很在理,我就想蹲一个结果 |
![]() | 41 ninvfeng PRO 1. 执行 du -sh / 看看哪个文件夹最大 2. 然后进最大的文件夹执行 du -sh ./* 重复执行第二步就能找到最大的文件在哪 如果删除后空间没释放就重启一下对应的程序 |
42 julyclyde 2022-12-29 09:07:58 +08:00 @ninvfeng2020 你这个和 OP 错的一样啊 |
![]() | 43 zhuanggu 2022-12-29 12:00:54 +08:00 不是文件夹大啊,而是根目录下有隐藏文件。ls -a |