linux No space left on device 问题解决

本文记录了一次解决网站无法登录及文件上传失败的问题过程。通过对错误日志的分析,发现是由于磁盘inode资源耗尽导致。通过检查磁盘空间、inode使用情况,并清理大量占用空间的文件,最终解决了问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题:网站无法登陆,上传文件失败 …
查找问题:
  1. 查看日志,出现如下错误:
PHP Warning:  session_start(): open(/var/tmp/php/session/sess_s0enu22sojitqshbm6bs4dsf95, O_RDWR) failed: No space left on device (28) in /var/www/sites/prod/include.inc.php on line 2, referer: http://www.yuming.com/photodetail.php?id=ozx6G1zs/Ti00C6Rk/A&from=groupmessage

问题是磁盘空间不足,无法写入session,这种原因通常是文件空间不足或者文件索引被占用完
2. 查看磁盘空间信息

df命令用于显示磁盘分区上的可使用的磁盘空间。默认显示单位为KB。可以利用该命令来获取硬盘被占用了多少空间,目前还剩下多少空间等信息。

[root@srv-web1 tkont]# df -h
Filesystem            Size  Used Avail Use% Mounted on
/dev/xvda1             20G  3.9G   15G  21% /
tmpfs                 1.9G     0  1.9G   0% 
/dev/www             158G   42G  109G  28% 

发现空间是足够的,然后df -i 查看了下inodes,发现根目录下的inodes值使用率为100%了

[root@srv-web1 tkont]# df -ih
Filesystem   Inodes  IUsed  IFree IUse% Mounted on
/dev/xvda1    1.3M    1.3M    0k   100% /
tmpfs         479K  1  479K  1% /dev/shm
/dev/www      10M 373K 9.7M  4% /var/www/sites
解决问题

通过以下脚本进行检查,查看到底哪个目录下面的文件最多,依次定位到最终最大的那个目录

for i in /*; do echo $i; find $i | wc -l; done

将大文件删掉,如果直接用rm -rf 会报错/bin/rm Argument list too long,用xargs 去避免这个问题

ls | xargs -n 10 rm -rf

然后登陆系统,问题最终解决!

问题总结

该问题从发现到解决总共花掉30分钟,定位问题相对容易,就是因为垃圾文件长时间没清理,导致清理文件花太多的时间,为了避免该类问题,最好对系统的垃圾文件进行定时清理,或者部署监视系统。

<think>好的,我现在需要帮助用户解决Linux系统中出现的“no space left on device”错误。首先,我得回忆一下这个错误的常见原因和解决方法。根据用户提供的引用内容,特别是引用[2]提到的,这个错误通常涉及磁盘空间不足或者inode耗尽两种情况。所以,我应该指导用户先检查这两方面。 首先,用户可能需要知道如何检查磁盘空间。命令df -h可以查看磁盘使用情况,而df -i则是检查inode的使用。这两个命令的结果会帮助确定是存储空间不足还是inode用完了。如果是存储空间问题,用户需要找到大文件或目录进行清理。这时候可能需要使用du命令来查找大文件,比如du -sh /* | sort -rh,但要注意可能需要权限。另外,用户可能需要清理日志文件、临时文件,或者旧的Docker镜像等,尤其是引用[3]提到的Docker相关问题,可能需要调整Docker的存储位置。 如果是inode耗尽的情况,通常是大量小文件导致的,比如临时文件或者缓存。这时候需要找到哪个目录下有大量小文件,可以用find命令加上-mtime参数来查找并删除旧文件。用户可能需要指导如何安全删除这些文件,避免误删重要数据。 另外,用户可能需要处理已删除文件但未释放空间的情况,比如被进程占用的文件。这时候lsof命令可以查看这样的文件,并重启相关进程来释放空间。 还需要考虑日志轮转和系统维护,比如使用logrotate来管理日志文件,避免它们占用过多空间。此外,设置监控或定时任务来预防未来的空间问题可能也是用户需要的。 在解释这些步骤时,要确保结构清晰,分点说明,让用户能够一步步操作。同时,注意提醒用户在删除文件前确认数据的重要性,避免误操作导致数据丢失。可能还需要根据用户的具体环境,比如是否使用Docker,给出相应的建议,比如修改Docker的存储目录到更大的分区。 最后,生成相关问题,帮助用户深入理解问题,比如如何监控磁盘空间,或者如何调整Docker配置,这些都能让用户进一步解决问题或预防未来的错误。</think>### Linux系统“no space left on device”错误解决方案 #### 一、诊断问题根源(两步排查) 1. **检查磁盘空间占用** ```bash df -h # 查看各分区使用率,重点关注使用率接近100%的分区 ``` - 若发现某个分区已满(例如`/dev/sda1`),需清理大文件或扩容 - 常见高占用目录:`/var/log`(日志)、`/tmp`(临时文件)、Docker存储目录(默认`/var/lib/docker`) 2. **检查inode使用情况** ```bash df -i # 查看inode剩余数量,小文件过多会导致inode耗尽 ``` - 若inode使用率100%,需清理大量小文件(如邮件队列、临时缓存等) --- #### 二、针对性解决方案 **场景1:磁盘空间不足** 1. **查找大文件/目录** ```bash du -sh /* | sort -rh # 扫描根目录下各子目录大小 cd /可疑目录 && du -sh * | sort -rh # 逐层定位具体文件 ``` 2. **常见清理操作** - **日志文件清理**: ```bash journalctl --vacuum-size=200M # 限制系统日志大小 rm /var/log/*.gz /var/log/*.old # 删除旧日志 ``` - **Docker清理**(参考引用[3]): ```bash docker system prune -a --volumes # 清理未使用的镜像、容器、卷 docker info | grep "Docker Root Dir" # 确认存储位置 ``` - **内核文件清理**: ```bash package-cleanup --oldkernels --count=2 # CentOS保留2个旧内核 ``` **场景2:inode耗尽** 1. **查找小文件集中目录** ```bash find / -xdev -type f | cut -d "/" -f 2 | sort | uniq -c | sort -n ``` 2. **清理方案** - **邮件队列**: ```bash postsuper -d ALL # 如果是邮件服务器 ``` - **PHP会话文件**: ```bash find /var/lib/php/sessions -type f -mtime +7 -delete ``` - **临时文件**: ```bash rm -rf /tmp/* ``` --- #### 三、特殊场景处理 **已删除文件但空间未释放**(进程仍占用文件句柄): 1. 查找被占用的已删除文件 ```bash lsof +L1 # 显示链接数为0的已删除文件 ``` 2. 重启相关进程释放空间 --- #### 四、预防措施 1. **日志轮转配置** ```bash vim /etc/logrotate.conf # 调整日志保留策略 ``` 2. **监控设置** ```bash # 添加crontab定时任务 */30 * * * * df -h >> /var/log/disk_usage.log ``` 3. **Docker存储迁移(参考引用[3])** ```bash systemctl stop docker rsync -av /var/lib/docker /new/path/ vim /etc/docker/daemon.json # 添加 "data-root": "/new/path/docker" systemctl start docker ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值