no space left on device 磁盘空间不足原因及排查方法

在系统使用中,经常会遇到no space left on device 磁盘空间不足的情况, 下面来详细的介绍一下产生这种情况的几种原因及解决办法:

1. 首先我们要清楚inode 和 block的概念:

  1. inode在格式化创建文件系统的时候诞生,用来存放文件的属性信息,存放着block的位置,没有文件名,创建一个非空文件占用一个inode和至少1个block

  2. 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]# \rm -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]# \rm -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

大家有什么好的方法或者其他解决思路,可以留言交流

你可能感兴趣的:(linux运维)