如何解决Linux no space left on device 报错?

原因1 inode不足

现象
=================
提示No space left on device,使用df -i查看,可以看到inode不足。


解决
=================
inode占用的很多,很可能是某个目录里的文件很多(一般是小文件),那么该目录的大小会很大,基于此,可以使用find命令找到大目录,即里面有大量小文件的目录,根据情况删除之
find / -type d -size +1M | xargs rm
删除大量小文件可以用 ls xargs | rm


可能的场景
=================
定时任务没有定向到黑洞,并且邮件服务没有开启,会导致产生大量小文件。

原因2 block不足

现象:提示No space left on device,使用df -i查看,inode正常,使用df -h,查看block,发现不足。

解决:找大文件同样可以用find、du等命令,根据情况文件能删则删,不能删则添加硬盘。

原因3 误删正在使用中的文件(进程调用不为零)

现象:提示No space left on device,使用df -i查看,inode正常,使用df -h查看block,满了。对比df -h和du -sh /,发现容量不匹配,du -sh /显示没满。lsof | grep deleted过滤,能够过滤出被误删的文件名。

解决:重启被误删文件对应的服务。

场景1:比如磁盘空间一共100G,使用的也是100G,这时候删除一个20G的正在使用的日志文件。df -h查看block还是满的,新建文件会提示No space left on device,但是du -sh /显示只用了80G。

场景2:并没有提示No space left on device,但是df -h和du -sh /容量不匹配,也说明误删了正在使用的文件。

这种情况更多细节参考:
如何解决Linux删除文件但是磁盘空间大小并没有释放的问题?
https://blog.csdn.net/xys2015/article/details/114290937
### Linux系统中“No space left on device”错误的解决方案 当Linux服务器报告“No space left on device”的错误时,这表明当前设备上的存储空间已被占满,无法继续创建新文件或上传数据。此问题可通过多种方法解决,具体取决于实际需求和环境设置。 --- #### 错误原因分析 该错误通常由以下几种情况引起: 1. 文件系统的可用磁盘空间耗尽。 2. inode数量不足,即使仍有磁盘空间也无法创建新文件。 3. 特定目录或分区的空间配额达到上限。 --- #### 解决方案 ##### 方案一:扩展现有磁盘分区 如果问题是由于物理磁盘容量不足引起的,可以考虑通过扩展磁盘分区来解决问题。例如,在CentOS环境中: 1. **查看磁盘使用情况** 使用`df -h`命令检查各分区的使用率,并识别哪个分区已满[^2]。 ```bash df -h ``` 2. **调整逻辑卷大小** 假设 `/dev/mapper/cl-root` 已满,而 `/dev/mapper/cl-home` 存在多余空间,则可将部分空间从 `cl-home` 转移到 `cl-root`。 - 缩小 `cl-home` 分区至所需最小值(如10GB): ```bash lvreduce -L 10G /dev/cl/home ``` - 将释放出来的空间分配给 `cl-root` 并更新 XFS 文件系统: ```bash lvextend -l +100%FREE /dev/cl/root xfs_growfs /dev/mapper/cl-root ``` 3. 验证更改后的磁盘状态: ```bash df -h ``` --- ##### 方案二:清理大文件和无用日志 如果磁盘空间有限且无法轻易扩展,可以通过删除不必要的大文件或旧日志来腾出空间。 1. **查找占用大量空间的文件** 列出大于1GB的文件并评估其必要性: ```bash find / -xdev -size +1G -exec ls -lh {} \; ``` 2. **清除临时文件和缓存** 删除不再需要的临时文件、缓存或其他冗余数据: ```bash rm -rf /var/tmp/* journalctl --vacuum-size=100M yum clean all ``` 3. **禁用或轮转过期日志** 修改日志保留策略以减少长期积累的影响: ```bash cat /etc/logrotate.conf vi /etc/logrotate.d/syslog ``` --- ##### 方案三:迁移Docker镜像到其他路径 针对运行容器化的应用环境,“no space left on device”也可能源自 Docker 的默认存储位置 (`/var/lib/docker`) 占用了过多空间。此时可以选择改变 Docker 数据目录的位置。 1. **查询当前 Docker 磁盘使用状况** 运行以下命令获取统计信息: ```bash docker system df ``` 2. **重置 Docker Root Directory** 创建一个新的挂载点并将 Docker 数据迁移到那里: ```bash mkdir /mnt/new-docker-storage rsync -aP /var/lib/docker/ /mnt/new-docker-storage/ systemctl stop docker mv /var/lib/docker /var/lib/docker.bak ln -s /mnt/new-docker-storage /var/lib/docker systemctl start docker ``` 3. 验证新的配置生效: ```bash docker info | grep "Docker Root Dir" ``` --- ##### 方案四:监控inode消耗 有时尽管磁盘显示还有剩余空间,但由于 inode 数量耗尽仍会报错。这种情况下需特别关注小型文件的数量增长趋势。 1. 检查 inode 使用比例: ```bash df -i ``` 2. 定位高密度的小型文件所在区域: ```bash find /path/to/directory -type f | wc -l ``` 3. 清理多余的零碎文件或将它们归档压缩保存。 --- ### 总结 以上提供了四种主要应对“No space left on device”错误的方法,分别适用于不同的场景和技术背景。实施过程中应注意操作的安全性和数据的一致性保护。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

凯尔kyle

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值