nospaceleftondevice
第一原因当然是磁盘空间不够用了
若是空间剩余很多还报这个错误,则可能是block不够用了!
- 首先我们要清楚inode 和 block的概念:
inode在格式化创建文件系统的时候诞生,用来存放文件的属性信息,存放着block的位置,没有文件名,创建一个非空文件占用一个inode和至少1个block
block是实际存放数据的位置,block大小 1k 4k 8k centos 6.x(分区大于500M 默认是4k),文件很大的话占用多个block, 文件非常小的时候1k block剩余的空间不能继续使用,所以系统中block消耗更快
所以磁盘慢了就分为,inode满了,和block满了,以及一种特殊的情况,下面我们来具体分析,以及对应的解决方案
查看是否是block满了
[root@test-os testuser]# df -h ###查看所有block使用情况 Filesystem Size Used Avail Use% Mounted on
/dev/sda3 8.8G 8.8G 0 100% /
tmpfs 931M 0 931M 0% /dev/shm
/dev/sda1 190M 40M 141M 22% /boot
[root@test-os testuser]# du -sh /usr/* |grep G ###查找大文件
7.3G /usr/local
[root@test-os testuser]# du -sh /usr/local/* |grep G
7.3G /usr/local/bin
[root@test-os testuser]# du -sh /usr/local/bin/* |grep G
7.3G /usr/local/bin/1g
[root@test-os testuser]# m -f /usr/local/bin/1g ###删除大文件
[root@test-os testuser]#
[root@test-os testuser]# df -h ###接着查看发现已经解决
Filesystem Size Used Avail Use% Mounted on
/dev/sda3 8.8G 1.5G 6.9G 18% /
tmpfs 931M 0 931M 0% /dev/shm
/dev/sda1 190M 40M 141M 22% /boot
查看是否inode满了(df -h发现还有空间)
[root@test-os logs]# touch {1..118}.txt [root@test-os logs]# touch {1..118}.txt
touch: cannot touch `118.txt": No space left on device
[root@test-os logs]# df -i ###查看inode使用情况
Filesystem Inodes IUsed IFree IUse% Mounted on
/dev/sda3 593344 56998 536346 10% /
tmpfs 238282 1 238281 1% /dev/shm
/dev/sda1 51200 39 51161 1% /boot
/tmp/1m 128 128 0 100% /app/logs
[root@test-os logs]# pwd
/app/logs
[root@test-os logs]# m -f *.txt ###如果小文件太多,采用a*.txt b*.txt 一批一批的删
[root@test-os logs]# df -i ###接着查看
Filesystem Inodes IUsed IFree IUse% Mounted on
/dev/sda3 593344 56998 536346 10% /
tmpfs 238282 1 238281 1% /dev/shm
/dev/sda1 51200 39 51161 1% /boot
/tmp/1m 128 11 117 9% /app/logs
###如果不知道小文件都在哪里怎么查找?
###查找系统中 目录大小大于1M(目录一般大小为4K,所以目录要是大了那么文件必然很多)
[root@localhost testuser]# find / -size +4k -type d |xargs ls -ldhi
11 drwx------ 2 root root 12K Sep 23 00:49 /boot/lost+found
946 drwxr-xr-x 12 root root 4.1K Sep 22 17:53 /dev
1114113 drwxr-xr-x 88 root root 12K Sep 22 19:55 /etc
262145 drwxr-xr-x 13 root root 12K Sep 22 18:59 /lib
查看是不是文件被占用一直没被彻底删除(特殊原因),这种情况往往是容易被忽略,也是让人郁闷的,因为你会发现df -h明明已经有空间了,但是就是放不进去东西
[root@test-os ~]# lsof |grep deleted rsyslogd 1250 root 1w REG 8,3 4888889358 140789 /var/log/messages (deleted)
[root@test-os ~]# #lsof 显示出系统中被打开的文件
[root@test-os ~]# #第一列 软件/服务的名称
[root@test-os ~]# #第八列 文件的大小
[root@test-os ~]# #第10列 文件的名字
[root@test-os ~]# #第11列 标记(硬链接数为0 进程调用数不为零 就会有 delete)
####重启对应的服务 释放磁盘空间
[root@test-os ~]# /etc/init.d/rsyslog restart
Shutting down system logger: [ OK ]
Starting system logger: [ OK ]
[root@test-os ~]# df -h
Filesystem Size Used Avail Use% Mounted on
/dev/sda3 8.8G 1.5G 6.9G 18% /
tmpfs 931M 0 931M 0% /dev/shm
/dev/sda1 190M 40M 141M 22% /boot
/tmp/1m 1003K 19K 933K 2% /app/logs
以上是 nospaceleftondevice 的全部内容, 来源链接: utcz.com/z/518528.html