全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Linux中出现“No space left on device”错误的排查与解决方法

前言

最近这两天登陆服务器,发现用 wget 下载文件的时候提示“No space left on device”,而且连使用 tab 键进行补全时也会提示该错误。

之前遇到过一次这种问题,是由于磁盘空间被占满了,导致无法创建新文件。正常情况下,删除一些文件来释放空间,即可解决该问题。

当我使用 df 命令查看分区情况时,结果如下:

# df -h
Filesystem Size Used Avail Use% Mounted on
/dev/vda1 29G 29G 0 100% /
udev  10M 0 10M 0% /dev
tmpfs  101M 232K 100M 1% /run
tmpfs  5.0M 0 5.0M 0% /run/lock
tmpfs  405M 0 405M 0% /run/shm

看到这里,我以为磁盘真的被 100% 占用了,于是就查看了各目录的占用情况:

# du -sh /*
8.8M /bin
30M /boot
0 /dev
5.3M /etc
24K /home
0 /initrd.img
205M /lib
4.0K /lib64
16K /lost+found
8.0K /media
4.0K /mnt
4.0K /opt
0 /proc
2.5G /root
232K /run
5.2M /sbin
8.0K /srv
0 /sys
4.0K /tmp
2.6G /usr
1.8G /var
0 /vmlinuz

很明显,总共的磁盘占用完全不到 10G,磁盘理论上并未被占满。

这种情况下,很可能是小文件过多,导致 inode 急剧增加,消耗完 inode 区域的空间。

如果真是如此,那么即使磁盘空间有剩余,但由于无法创建新的 inode 来存储文件的元信息,也就无法创建新文件。

因此,我用 df 命令进行验证:

# df -ih
Filesystem Inodes IUsed IFree IUse% Mounted on
/dev/vda1 1.9M 299K 1.6M 17% /
udev  123K 299 123K 1% /dev
tmpfs  126K 249 125K 1% /run
tmpfs  126K 4 126K 1% /run/lock
tmpfs  126K 2 126K 1% /run/shm

可以看到,inode 区域只被占用了一小部分,还有大量的空间未使用,所以也不是 inode 区域被占满的问题。

到了这里,我的内心是非常郁闷的。这个问题直接导致了Apache、MySql以及其它的一些服务均无法启动,服务器已经基本没法使用了,然而原因却扑朔迷离。

最后,服务器提供商告诉我另一种可能的情况,就是有些文件删除时还被其它进程占用,此时文件并未真正删除,只是标记为 deleted,只有进程结束后才会将文件真正从磁盘中清除。

于是我通过 lsop 命令查看了被进程占用中的文件:

# lsof | grep deleted
mysqld 1952 2982 mysql 5u REG  254,1  0 127 /tmp/ibzMEe4z (deleted)
mysqld 1952 2982 mysql 6u REG  254,1  0 146 /tmp/ibq6ZFge (deleted)
mysqld 1952 2982 mysql 10u REG  254,1  0 150 /tmp/ibyNHH8y (deleted)
apache2 2869  root 9u REG  254,1  0 168 /tmp/.ZendSem.2w14iv (deleted)
apache2 2869  root 10w REG  0,16  0 11077 /run/lock/apache2/rewrite-map.2869 (deleted)
...
python 3102  root 1w REG  254,1 22412342132 264070 /var/log/nohup.out (deleted)

终于找到了罪魁祸首,原来是在后台运行的 Python 脚本,源源不断地将输出保存到 /var/log/nohup.out 文件中,文件大小居然达到了20G+!

前阶段在后台运行脚本之后,就没再管过它。估计是我在 Python 运行过程中删掉了 nothup.out 文件,由于该文件被占用,所以只能先标记为 deleted,而未真正删除,最后导致磁盘爆满。

这次的教训提醒了我,不能将任务简单放到后台就放任不管,特别是使用 nohup 命令时,所有的输出都会被不断地添加到同一个文件中,如果该进程不会自己终止,就可能导致输出文件占满整个磁盘。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。


# no  # space  # left  # device  # linux  # Linux使用vim编辑文件保存时报E514:write error (file system fu  # 使用‘fsck’修复Linux中文件系统错误的方法  # 关于Read-only file system问题的解决  # 看了  # 用了  # 磁盘空间  # 情况下  # 占满  # 新文件  # 是在  # 我在  # 也会  # 告诉我  # 也就  # 当我  # 这个问题  # 我用  # 达到了  # 可以看到  # 很可能  # 满了  # 扑朔迷离  # 这篇文章 


相关文章: C++如何将C风格字符串(char*)转换为std::string?(代码示例)  免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?  如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?  成都响应式网站开发,dw怎么把手机适应页面变成网页?  焦点电影公司作品,电影焦点结局是什么?  东莞市网站制作公司有哪些,东莞找工作用什么网站好?  宁波自助建站系统如何快速打造专业企业网站?  如何通过PHP快速构建高效问答网站功能?  怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?  公司网站建设制作费用,想建设一个属于自己的企业网站,该如何去做?  如何通过虚拟主机空间快速建站?  黑客如何通过漏洞一步步攻陷网站服务器?  怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?  如何通过VPS建站无需域名直接访问?  如何通过WDCP绑定主域名及创建子域名站点?  建站主机系统SEO优化与智能配置核心关键词操作指南  高端智能建站公司优选:品牌定制与SEO优化一站式服务  专业制作网站的公司哪家好,建立一个公司网站的费用.有哪些部分,分别要多少钱?  网站制作软件有哪些,制图软件有哪些?  如何快速搭建个人网站并优化SEO?  制作电商网页,电商供应链怎么做?  定制建站方案优化指南:企业官网开发与建站费用解析  建站主机如何选?高性价比方案全解析  南京做网站制作公司,南京哈发网络有限公司,公司怎么样,做网页美工DIV+CSS待遇怎么样?  深圳网站制作平台,深圳市做网站好的公司有哪些?  制作网站公司那家好,网络公司是做什么的?  婚礼视频制作网站,学习*后期制作的网站有哪些?  南京网站制作费用,南京远驱官方网站?  想学网站制作怎么学,建立一个网站要花费多少?  视频网站制作教程,怎么样制作优酷网的小视频?  做企业网站制作流程,企业网站制作基本流程有哪些?  如何在云主机上快速搭建多站点网站?  GML (Geography Markup Language)是什么,它如何用XML来表示地理空间信息?  广州营销型建站服务商推荐:技术优势与SEO优化解析    如何在橙子建站上传落地页?操作指南详解  长沙做网站要多少钱,长沙国安网络怎么样?  阿里云网站制作公司,阿里云快速搭建网站好用吗?  广州网站设计制作一条龙,广州巨网网络科技有限公司是干什么的?  建站之星CMS建站配置指南:模板选择与SEO优化技巧  如何高效完成自助建站业务培训?  宝塔面板创建网站无法访问?如何快速排查修复?  网站制作软件免费下载安装,有哪些免费下载的软件网站?  定制建站是什么?如何实现个性化需求?  如何通过多用户协作模板快速搭建高效企业网站?  官网自助建站平台指南:在线制作、快速建站与模板选择全解析  东莞专业制作网站的公司,东莞大学生网的网址是什么?  网站制作企业,网站的banner和导航栏是指什么?  如何确保西部建站助手FTP传输的安全性?  如何用IIS7快速搭建并优化网站站点? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。