博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Web服务器磁盘满故障
阅读量:5313 次
发布时间:2019-06-14

本文共 2849 字,大约阅读时间需要 9 分钟。

问题:

硬盘显示被写满,但是用du -sh /*查看时占用硬盘空间之和还远小于硬盘大小,即找不到硬盘分区是怎么被写满的。

今天下午接到同事紧急求助,说生产线服务器硬盘满了。该删的日志都删掉了。可空间还是满的,情况危急啊。这个问题,在多年以前直接和间接的遇到过1-2次。以前太懒惰了,这次记录下来和大家分享。

相关日志如下:

█ 查看硬盘分区大小

1 [root@www ~]# cat /etc/redhat-release 2 CentOS release 6.4 (Final)3 [root@www ~]# df -h4 Filesystem            Size  Used Avail Use% Mounted on5 /dev/sda3             117G  111G     0 100% /6 /dev/sda1             145M   12M  126M   9% /boot7 tmpfs                 3.0G     0  3.0G   0% /dev/shm

这是一台web服务器(apache+tomcat+mysql)

通过dh -h命令查看 总大小117G,使用了111G

1 [root@www /]# fdisk -l 2  3 Disk /dev/sda: 146.8 GB, 146815733760 bytes 4 255 heads, 63 sectors/track, 17849 cylinders 5 Units = cylinders of 16065 * 512 = 8225280 bytes 6  7    Device Boot      Start         End      Blocks   Id  System 8 /dev/sda1   *           1          19      152586   83  Linux 9 /dev/sda2              20        2108    16779892+  82  Linux swap / Solaris10 /dev/sda3            2109       17849   126439582+  83  Linux 11 [root@www /]# fdisk -l /dev/sda312 13 Disk /dev/sda3: 129.4 GB, 129474132480 bytes14 255 heads, 63 sectors/track, 15741 cylinders15 Units = cylinders of 16065 * 512 = 8225280 bytes16 17 Disk /dev/sda3 doesn't contain a valid partition table

==========================================================================================

█ 使用du命令查看到底哪些目录占用了空间

[root@www /]# du -sh /*8.6M    /bin6.1M    /boot2.8G    /data ===》这里是DB目录124K    /dev60M     /etc1.6G    /home ===》这里是日志目录120M    /lib24M     /lib6416K     /lost+found8.0K    /media0       /misc12K     /mnt0       /net8.0K    /opt0       /proc614M    /root35M     /sbin8.0K    /selinux24K     /server8.0K    /srv0       /sys24K     /tmp2.5G    /usr29G     /var  ==》这里是www目录

可以看出,上面所有目录之和 远小于总的空间占用111G,是什么占用了硬盘,还查不到呢?

解答:

出现上面问题原因:

在apache/tomcat服务在运行状态下,清空了运行服务的日志,这里是清理了当天或正在写入的apache及tomcat的日志文件,从而导致了上面问题。(有关原理细节见下文)引申下:一般情况下,大多数服务(包括脚本)在运行时,是不能删除当前正在写入的日志文件的。这点请大家要记牢。

本文的解决办法:

查找机器自身的服务,然后重起apache和tomcat。
重起apache后:

1 [root@www ]# df -h2 Filesystem            Size  Used Avail Use% Mounted on3 /dev/sda3             117G  109G  2.3G  98% /4 /dev/sda1             145M   12M  126M   9% /boot5 tmpfs                 3.0G     0  3.0G   0% /dev/shm

重起tomcat后:

[root@www ~]# df -hFilesystem            Size  Used Avail Use% Mounted on/dev/sda3             117G   38G   74G  34% //dev/sda1             145M   12M  126M   9% /boottmpfs                 3.0G     0  3.0G   0% /dev/shm

 上面问题原理分析:

1、这是一个文件系统层面的技术2、当前 access.log 日志正被 apache 进程占用。通过 rm 命令删除 access.log,实际只删除了文件名(该日志文件应用记数不 0,因此空间不会被释放)3、rm 命令删除了 access.log 后 apache 依然写日志到 access.log 中,当开启 apache 进程是,已经通过 access.log 定位到文件的 inode 了就是说再写日志是不通过 access.log,因此,即使删除了 access.log,apache 依然写日志到 access.log 所在的 inode 节点,所以导致硬盘空间增加。4、因为删除了 access.log,所以,我们人类就看不到相关文件了,也就是说找不到该文件,du 也查不到。所以就会发现磁盘满而看不到什么文件撑满的硬盘,

 

转载于:https://www.cnblogs.com/luoahong/p/6197842.html

你可能感兴趣的文章
Linux 终端连接工具 XShell v6.0.01 企业便携版
查看>>
JS写一个简单日历
查看>>
Python 发 邮件
查看>>
mysql忘记密码的解决办法
查看>>
全面分析Java的垃圾回收机制2
查看>>
[Code Festival 2017 qual A] C: Palindromic Matrix
查看>>
修改博客园css样式
查看>>
Python3 高阶函数
查看>>
初始面向对象
查看>>
leetcode Letter Combinations of a Phone Number
查看>>
Unity 5.4 测试版本新特性---因吹丝停
查看>>
7.5 文件操作
查看>>
DFS-hdu-2821-Pusher
查看>>
MyEclipse中将普通Java项目convert(转化)为Maven项目
查看>>
node js 安装.node-gyp/8.9.4 权限 无法访问
查看>>
windows基本命令
查看>>
VMware中CentOS设置静态IP
查看>>
[poj1006]Biorhythms
查看>>
Hyper-V虚拟机上安装一个图形界面的Linux系统
查看>>
Hover功能
查看>>