1.2.8. linux问题汇总

/root挂载点没空间解决方案

> dpkg –get-selections|grep linux
> apt-get remove <soft_version>

使用du与df命令查看磁盘容量不一致

问题

  • 问题1:执行df -h查看文件系统的使用率,可以看到/dev/xvdb1磁盘占用了约27G,挂载目录为/opt:

    # df -h
    Filesystem      Size  Used Avail Use% Mounted on
    /dev/vda1        99G   84G  9.8G  90% /
    ...
    

进入到/opt目录执行du -sh,显示空间总占用量约2.4G,即df与du命令查看到的结果不一致:

$> du -hs
14.7G  /
  • 问题2:通过df -h命令查看磁盘使用情况显示的是负值,如下图所示:

    # df -h
    Filesystem      Size  Used    Avail   Use%    Mounted on
    /dev/vda1        99G   -5.4G  9.8G    90%      /
    ...
    
  • 问题3:执行du和df命令显示的容量不一致,df比du命令显示的数据大很多

  • 问题4:使用df命令查询磁盘占用率很高,但是用du命令统计目录时却发现很低,且查不到已删除的句柄文件

  • 问题5:当前系统存在数据盘挂载点.使用df命令查看系统盘占用容量已满,但是在根目录下使用du命令统计各文件总容量,合计并达不到总容量

问题原因

  • 问题1的原因是用户删除了大量的文件后,du命令就不会在文件系统目录中统计这些文件:

    如果此时还在运行中的进程持有这个已经被删除的文件句柄,那么这个文件就不会真正在磁盘中被删除
      分区超级块中的信息也就不会更改,df命令仍会统计这个被删除的文件。
    通过lsof命令查询处于deleted状态的文件,被删除的文件在系统中被标记为deleted
    如果系统有大量deleted状态的文件,会导致du和df命令统计结果不一致。
    

可在opt目录下执行如下命令查看:

lsof |grep deleted
  • 问题2的原因是Linux系统磁盘分区有保留区的概念,会给root或指定用户预留5%或更大的空间:

    当使用到这块保留区的空间时,fdisk命令的计算将会是负数
    ext文件系统(包括 ext2、ext3、ext4)都会默认预留5%的磁盘空间
        使用root用户维护系统或记录系统关键日志使用
    
  • 问题3的原因是当用 du -sh * 命令来统计目录总容量时,如果该路径下包含隐藏文件,不会包含在统计结果里

  • 问题4的原因是由于删除了大量小文件,导致inode释放出现问题

  • 问题5的原因是由于数据盘挂载前该路径下就存在文件,挂载后用du无法查询到原路径文件

解决方案

本文主要针对以上五种问题,提供以下解决方案:

问题1的解决方法是根据lsof列出的进程号,终止相应进程或者重启相应的服务
  也可以重启实例,重启实例系统会退出现有的进程,开机后重新加载过程中,会释放调用的deleted文件的句柄
  提示:如果ECS实例正在运行业务进程,终止进程时请慎重操作。
问题2的解决方法是通过rm命令删除磁盘中的大文件,释放预留空间的占用后,再通过df命令查询磁盘占用即可恢复正常
问题3的解决方法是执行du -ah命令即可在统计结果中包含隐藏文件
问题4的解决方法是执行fsck命令后即可恢复正常
问题5的解决方法是卸载数据盘后再次使用du命令查询即可查到数据