Linux使用中出现no space left on device错误-程序员宅基地

技术标签: 运维  linux  服务器  

查询资料所录,有不足欢迎补充

目录

### 错误解析:

### 错误检测:磁盘的整体数据存储在超级区块中,但每个文件的容量记载于inode当中,可用df或du命令查看,详解如下:

### 解决方向:

#### ① block已满

#### ②inode已满

#### ③已删除的文件占用进程


### 错误解析:

  • 文件系统已满:所有的inode或者磁盘块都被使用完
  • 小文件占用大量空间:由于Linux文件系统存在块分配的最小单位(如1KB),即使文件很小,它也会占用一个完整的块
  • 磁盘碎片:文件可能分散存储在不同的物理位置,导致看起来空间总和不足
  • 未删除的文件:即使文件被删除,它们的索引节点仍然在文件系统中,直到新的文件写入覆盖

### 错误检测:磁盘的整体数据存储在超级区块中,但每个文件的容量记载于inode当中,可用df或du命令查看,详解如下:

  • df:列出文件系统的整体磁盘使用量;

-a:列出所有的文件系统,包括系统特有的/proc等文件系统

-h:以人们较易阅读的GBytes、Mbytes、KBytes等格式自行显示

-i:不用磁盘容量,而以inode的数量来显示

  • du:查看文件系统的磁盘使用量(常用于在查看目录所占磁盘空间);

-a:列出所有的文件与目录容量

-h:以人们较易读的容量格式(G/M)显示

-s:仅列出总量,而不列出每个个别的目录占用容量

### 解决方向:

  • 使用df -Th命令查看磁盘使用情况 

文件系统        类型      容量   已用 可用       已用%  挂载点

Filesystem     Type      Size  Used    Avail   Use%  Mounted on
devtmpfs    devtmpfs  476M     0      476M   0%      /dev
tmpfs          tmpfs        487M     0      487M   0%     /dev/shm
tmpfs          tmpfs        487M  7.7M   479M   2%     /run
tmpfs          tmpfs        487M     0      487M   0%     /sys/fs/cgroup
/dev/sda3      xfs         10G    7.1G    2.9G    71%   /
/dev/sr0     iso9660     9.5G   9.5G    0         100%  /media
/dev/sda1      xfs         197M  110M   88M     56%   /boot
tmpfs          tmpfs        98M     0        98M     0%     /run/user/0

注: /dev/sr0代表光驱,是写受保护的,通常是只读的,所以使用率是100%代表这个挂载点被这个光驱设备占用了,因此没有剩余空间

除此之外可以看到根分区的文件系统/dev/sda3已使用71%

        B

可通过block和inode的区别_inode和block的区别-程序员宅基地查看二者区别

#### ① block已满

1、若显示磁盘已用100%则代表磁盘已无剩余空间,可以通过如下操作解决:

第一种:删除不常用文件--也可将不常用的压缩包删掉

#进入根目录
cd /
#查看根目录下各文件夹大小情况并过滤1M及以上的进行排序
du -sh *|grep [MGT]|sort
#可选择删除/tmp/下的将不再使用的文件或目录
#下面命令中的file指"不再使用"的文件,dir指"不再使用"的目录
rm -rf /tmp/file
或rm -rf /tmp/dir

第二种:扩展分区--确定好根分区挂载的磁盘分区之后是否已经有分区存在,若没有则可扩展分区

进入虚拟机,选中 设置->添加->硬盘->SCSI->创建新虚拟磁盘->最大磁盘大小(GB)(S):20.0、将虚拟磁盘拆分成多个文件->默认文件名->完成->确定

#查看扩容前分区情况
df -Th
#查看是否有刚刚添加的分区--见代码段下图
fdisk -l
#分区
fdisk /dev/sdb

######
Command (m for help): n  # 输"n"新建分区
Command action
   e    extended
   p    primary partition (1-4)
Partition number(1-4): 1  # 分区号,输"1"
Last cylinder,+cylinders or +size{K,M,G} (1-1044,default 1044): +1G # 输入"+1G"定义该分区大小
#其余皆默认操作"Enter"即可
Command (m for help): t   # 输"t"改变类型
Hex code (type L to list all codes): 8e  #修改分区ID为LVM的分区代码
#默认操作"Enter"即可
Command (m for help): w   # 保存操作
######
#加载到内核
partx /dev/sdb1 或 partprobe /dev/sdb1
#格式化
mkfs.xfs /dev/sdb1
#查看分区结果
fdisk -l
#将新加的硬盘创建为物理卷(PV)--可用"vgdisplay"命令查看最终扩展的卷组大小
pvcreate /dev/sdb1
#查看上条命令是否有效
pvdisplay
#创建卷组(VG)--可用"vgdisplay"命令查看卷组,VG Name为卷组命名,为下面命令中的"centos"
vgcreate centos /dev/sdb1
##若卷组之前创建过则使用下条命令将物理卷加入卷组
# vgextend centos /dev/sdb1
#创建逻辑卷(LV)--创建一个名为"1v1",大小为100MB的逻辑卷,小分区可减少执行时间,该逻辑卷使用上面创建的卷组的空间
lvcreate -L 100M -n 1v1 centos
#格式化和挂载逻辑卷
mkfs.ext4 /dev/centos/1v1
##创建挂载目录
mkdir /lvm-mount
#挂载
mount /dev/centos/1v1 /lvm-mount/
#查看VG大小
vgdisplay
#扩容lv,并查看pv,vg和lv状态--"/dev/sda3" 为需要扩容的根分区的文件系统
lvextend -l +100%FREE /dev/sda3
##查看pv,vg和lv状态
命令分别为:pvs vgs lvs
#扩容根分区的文件系统
xfs_growfs /dev/sda3
#查看扩容后分区情况,查看变化
df -Th

 第三种(避免方法):通过写脚本及定时任务定时处理不常用文件

可通过“journalctl ”查看系统启动日志,查看是否有日志被占用

#创建放置脚本的目录
mkdir /data
cd /data
#编辑脚本--我的日志文件大都存在于/var/log/下,大家可根据自己需要写出日志文件目录
#注:里面比较重要的文件有“/var/log/messages”、“/var/log/wtmp”等,其他不重要的日志可以删除--经过查阅的结果,"*.log结尾的"放心删^-^
vim cleanLog.sh
######
find /var/log/ -name "*.log" -type f -print -exec truncate -s 0 {} \;
######
#为脚本添加可执行权限
chmod +x cleanLog.sh
#添加服务器定时任务
##编辑定时任务
crontab -e
######每天0点10分执行
10 0 * * * /data/cleanLog.sh
######
#查看定时任务是否生效
crontab -l 
#### ②inode已满

#查看inode节点是否用完
df -i

第一种: 见block已满的第二种扩展分区方法,在增加磁盘空间的同时inode节点数会增加

注:inode节点数与磁盘大小成正比

第二种:修改inode数量占用百分比(仅适用于xfs)

#查看xfs文件系统信息--"/dev/sda3"使用我上面提到的block已满的例子

xfs_info /dev/sda3

#修改inode数量占用百分比(m的值越大,inode数越大)

xfs-growfs -m 30 /dev/sda3

第三种(不建议):删除 /data/cache目录中的部分文件,释放出/data分区的一部分inode

# /var/spool/mail 是要删除的文件所在的目录 -type f这个参数限定find只查找普通文件(即不是管道文件,不是块文件,不是链接文件,不是目录等),防止误删除系统文件。
find /var/spool/mail -type f -print -exec rm -f {} \;
##原因分析:系统中有用户开启了cron,而cron中执行的程序有输出内容,输出内容会以邮件形式发给cron的用户,而sendmail没有启动所以就产生了这些文件;
#### ③已删除的文件占用进程
#使用lsof命令查找打开文件的进程:
lsof | grep deleted

######
进程名   PID       USER    FD   文件类型        大小(字节)  索引节点  文件名  [(状态)]

mysqld  925        mysql    6u      REG                8,3         0    8388674 /tmp/ibVXtA8h (deleted)
######
#使用kill命令终止进程--加进程号PID
kill -9 PID

以上是我罗列的no space解决方法,欢迎技高者提点,我继续补充!

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/m0_73705628/article/details/136681042

智能推荐

设置Socket的选项_socket nodely-程序员宅基地

文章浏览阅读4.6k次。Socket有以下几个选项。TCP_NODELY:表示立即发送数据SO_RESUSEADDR:表示是否允许重用Socket所绑定的本地地址SO_TIMEOUT:表示接收数据时的等待超时时间SO_LINGER:表示当执行Socket的close()方法时,是否立即关闭底层的SocketSO_SNFBUF:表示发送数据的缓冲区大小SO_RCVBUF:表示接受数据的缓冲区大小SO_KE_socket nodely

Snap7 西门子S7系列PLC的通信库 简介_snap7官网-程序员宅基地

文章浏览阅读3.2w次,点赞29次,收藏203次。目录简介参考Snap7 简介Snap7 用途适用系统支持语言西门子S7通信介绍Snap7 组件Sanp7 APISnap7 PythonSnap7 安装PLC设置连接PLC读取数据发送数据Sanp7 C/C++node.js简介最近在开发一个项目,作为技术帝,已经完成工艺、机械设计的设计,项目过多,也是为了让自己更加????叉,就开始尝试做电气制图和PLC编程。结合物联网的发展,有一种想法,将数据传..._snap7官网

HashMap和ConcurrentHashMap底层实现原理以及JDK1.7和1.8之间的区别_concurrent hash map,在jdk1.7和1.8的底层原理有什么区别,为什么1.8要做-程序员宅基地

文章浏览阅读554次,点赞2次,收藏6次。HashMap原理:HashMap主要由数组和链表组成,他不是线程安全的。核心的点就是put插入数据的过程,get查询数据以及扩容的方式。put元素: 在put插入的时候会根据key的hashcode去做hash运算得到一个index值(利用元素key的哈希值对数组长度-1按位与操作得到,为什么不用取模%运算呢?因为java的%比位运算慢10倍左右),根据index值放入数组的相应位置。每一个节点(Node)都会保存自身的hash、key、value、以及下个节点为什么要有链表: 因为不同的key可_concurrent hash map,在jdk1.7和1.8的底层原理有什么区别,为什么1.8要做出这

苹果开发者账号(公司级)和邓白氏编码(D-U-N-S)申请记录(2015.06)_legal entity name d-u-n-s庐 number-程序员宅基地

文章浏览阅读3.5w次。图文记录苹果开发者账号(公司级)和邓白氏编码(D-U-N-S)申请流水过程申请于2015.05-06份,算是较新的版本,有需要可以参考下_legal entity name d-u-n-s庐 number

【持续更新,后面带JavaWeb案例】IDEA2023创建JavaWeb项目的方法以及JavaWeb实现购物车案例_idea2023社区版提供web开发吗-程序员宅基地

文章浏览阅读1.1k次,点赞2次,收藏8次。哎呀我的妈妈咪呀,我来讲讲我为啥要写这篇文章。我tm之前用IDEA写Java 电脑项目习惯了,创建项目的时候就直接 新建项目,然后Java > Maven啥的,弄一大堆,然后写好页面和Servlet之后运行tomcat之后,用localhost:8080/项目名称/servlet名直接是找不到资源,搞我心态搞了现在tmb一个月,现在我总算明白了,那个初始模板可能有些插件/模块啥的自己不知道引用哪些,所以先开始总是报红,然后在web.xml里面写也tmd爆红,我真是服了!_idea2023社区版提供web开发吗

黑盒测试简介以及方法简介_一个循环条件为≤时,却错误写成<,用哪种测试方法能够找到这个错误-程序员宅基地

文章浏览阅读2w次,点赞9次,收藏49次。引言:黑盒测试是从软件的外部对软件实施测试,也常形容为闭着眼睛测试。在接下来的学习中将介绍几种常用的黑盒测试方法,其中包括等价类划分、边界值分析、决策表测试等。1. 等价类划分测试等价类划分是一种典型的黑盒测试方法,该方法完全不考虑程序的内部结构,只根据对软件的要求和说明,即需求规格说明,把程序输入域划分成若干个部分,然后从每个部分中选取少数有代表性的数据作_一个循环条件为≤时,却错误写成<,用哪种测试方法能够找到这个错误

随便推点

课设——学生成绩管理系统.exe_学生成绩统计系统exe-程序员宅基地

文章浏览阅读1k次,点赞3次,收藏7次。一、系统需求分析1、总需求设计一个实用的小型学生成绩管理程序,具有查询,检索和删除等功能。2、具体需求(1)学生基本信息、考试科目及成绩的信息录入。(2)已有学生信息的显示。(3)学生基本信息的读取和保存输入数据等功能(4)学生基本信息的查询与修改。可以对已有的学生信息进行修改。(5)学生基本信息的删除。(6)对该班各科成绩进行分析;对学生成绩进行统计(包括最高分,最低分,排序,平均成绩,及格率和需要补考的学生)具体源码详见(链接)二、总体设计1、定义四个类Student类、S_学生成绩统计系统exe

使用pdf.js不依赖任何activeX控件_pdfjs view.html怎么传入file文件参数-程序员宅基地

文章浏览阅读971次。使用pdf.js可以直接在浏览器上浏览PDF文件,而且不依赖任何activeX控件~ github上下载生成好的pdf.js工程本机项目:PDFPrintTest下demoviewer.js中要增加CORS跨域访问限制判断,否则不能跨域访问,或者在HOSTED_VIEWER_ORIGINS数组中增加viewer.html所在主机IP:PORT。作为不校验同源的ip_pdfjs view.html怎么传入file文件参数

Python 中 float 计算精度问题_python float 精度-程序员宅基地

文章浏览阅读7.5k次,点赞3次,收藏12次。浮点数不能精确的表示十进制数,并且即使是最简单的数学运算也会产生误差。该错误是由于浮点数的存储方式引起的。_python float 精度

HT合泰单片机入门教程(第一章 HT单片机环境搭建)-程序员宅基地

文章浏览阅读1.3w次,点赞21次,收藏115次。HT合泰单片机入门教程系列文章目录前言一、合泰单片机的优势二、HT-IDE3000安装1.HT-IDE3000下载2.HT-IDE3000安装总结系列文章目录# 第一章 HT单片机环境搭建目录系列文章目录前言一、合泰单片机的优势二、HT-IDE3000安装1.HT-IDE3000下载2.HT-IDE3000安装总结前言工作已经很长一段时间,虽然还是菜鸟一只。但还是有点心得体会。写合泰单片机系列教程的原因:一、是为了记录自己学习过程和学习经历(ps:当初毕业进公司接触到的第一个就是为一款已_合泰单片机入门教程

Android之如何获取手机中所有的传感器_导出智能手机中的传感器数据-程序员宅基地

文章浏览阅读7.1k次。传感器是第二代智能手机的重要标志之一。可以毫不客气地说,现在市面上的Android手机和平板电脑(TV除外)都内置了传感器。否则很多游戏和应用就无法使用了。Android SDK支持的传感器并不是每一部Android设备都支持所有的传感器。大多数Android设备只支持一部分传感器。例如,方向传感器(电子罗盘)、重力传感器(屏幕翻转、赛车游戏等)。动作(Motion)传感器环境(E_导出智能手机中的传感器数据

基于R的ggplot2包画KEGG富集通路气泡图_KEGGdot_ggplot 高低通路kegg-程序员宅基地

文章浏览阅读6.4k次,点赞2次,收藏16次。背景**基于公司已给出的结果上做出调整(公司只给出了top10),画KEGG富集通路的气泡图,初始文件如下图代码演示> getwd() #显示工作目录> setwd() #如果上述显示不是想要的路径,可以新建一个文件夹然后设置成工作目录,方便一些原始文件以及结果图片的存放> install.packages("ggplot2",destdir="D:/RData/R-win-4.0.2/R-4.0.2/R-packages",lib="D:/RData/R-win-4.0.2_ggplot 高低通路kegg