Linux使用中出现no space left on device错误

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

目录

### 错误解析:

### 错误检测:磁盘的整体数据存储在超级区块中,但每个文件的容量记载于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的区别-CSDN博客查看二者区别

#### ① 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
# 将新加的硬盘创建为物理卷--可以使用fdisk -l查看新加的磁盘是/dev/sdb'
pvceate /dev/sdb1
# 把物理卷加到卷组里
vgextend centos /dev/sdb1
#扩容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解决方法,欢迎技高者提点,我继续补充!

  • 30
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值