现象描述
在 Linux 云服务器中创建新文件的时候,出现 “no space left on device” 报错。
可能原因
- 硬盘空间已满
- 文件系统
inode
满 - df du 不一致
- 文件已删除,但仍有进程一直持有对应的文件句柄,导致硬盘空间一直未释放。
- mount 挂载嵌套。例如,系统盘的
/data
目录占用大量的空间,/data
又作为挂载点,挂载到其他数据盘,则会出现在系统盘 df du 不一致情况。
解决思路
参考 处理方法 排查并解决问题。
处理方法
解决硬盘空间已满问题
- 登录云服务器,详情请参见 使用标准登录方式登录 Linux 实例。
- 执行以下命令,查看硬盘使用率。
df -h
- 定位硬盘使用率较高的挂载点,并执行以下命令进入该挂载点。
例如,如需 cd 系统盘挂载点,则执行cd 对应挂载点
cd /
。 - 执行以下命令,查找占用空间较大的目录。
根据定位到占用空间最大的目录容量情况,执行以下步骤:du -x --max-depth=1 | sort -n
- 目录容量远低于硬盘总空间,则请参考 解决 df du 不一致问题 步骤继续排查问题。
- 目录容量较大,则请执行 步骤2 定位到占用空间较大的文件,综合业务情况评估是否可删除。若无法删除,则请通过 扩容云硬盘 扩大硬盘存储空间。
解决文件系统 inode 满问题
- 登录云服务器,详情请参见 使用标准登录方式登录 Linux 实例。
- 执行以下命令,查看硬盘使用率。
df -i
- 定位硬盘使用率较高的挂载点,并执行以下命令进入该挂载点。
例如,如需 cd 系统盘挂载点,则执行cd 对应挂载点
cd /
。 - 执行以下命令,查找文件个数最多的目录,解决该问题。该命令较耗时,请耐心等待。
find / -type f | awk -F / -v OFS=/ '{$NF="";dir[$0]++}END{for(i in dir)print dir[i]" "i}' | sort -k1 -nr | head
解决 df du 不一致问题
解决进程占用文件句柄问题
执行以下命令,查看占用文件的进程。
lsof | grep delete
请根据返回结果,执行以下步骤:
- kill 对应进程。
- 重启服务。
- 若较多进程占用文件句柄,可重启服务器。
解决 mount 挂载嵌套问题
- 执行 mount 命令,mount 占用空间大的磁盘到
/mnt
。例如:mount /dev/vda1 /mnt
- 执行以下命令,进入
/mnt
。cd /mnt
- 执行以下命令,查找占用空间较大的目录。
根据返回结果,综合业务情况评估是否可删除目录或文件。du -x --max-depth=1 | sort -n
- 执行 umount 命令,umount 磁盘。例如:
umount /mnt