Linux 不杀进程的情况下,如何释放磁盘资源
最近项目组人员反馈一个问题:即磁盘空间满了,但是并没看到有什么文件占用空间:
[root@xxxx home]# df -h
Filesystem Size Used Avail Use% Mounted on
/dev/xvda2 40G 6.4G 31G 18% /
tmpfs 7.8G 0 7.8G 0% /dev/shm
/dev/xvda1 190M 46M 135M 26% /boot
/dev/xvda3 40G 39G 0G 100% /home
/dev/xvda5 40G 49M 38G 1% /tmp
[root@xxxx home]# pwd
/home
[root@xxxx home]# du -sh
5.4G .
[root@IHSwaiwang7 home]# ls -a
. .. appuser ftp_dir linux lost+found
为什么磁盘空间大小显示不准确呢?
有隐藏文件?还是其他原因?
du -sh 命令统计了整体的空间使用率,隐藏文件也能被统计进去。
ls -lah 也没看到有问题的文件
然后想到是不是有些文件被删除,但是资源并未释放呢?
在Linux或者Unix系统中,通过rm或者文件管理器删除文件将会从文件系统的目录结构上解除链接(unlink).然而如果文件是被
打开的(有一个进程正在使用),那么进程将仍然可以读取该文件,磁盘空间也一直被占用。
查看被打开的已删除文件:
[root@xxxx home]# lsof -n | grep deleted
java root 1w REG , /home/appuser/tomcat7-MIR-/logs/catalina.out (deleted)
java root 2w REG , /home/appuser/tomcat7-MIR-/logs/catalina.out (deleted)
java root 8w REG , /home/appuser/tomcat7-MIR-/logs/localhost.--.log (deleted)
java root 42w REG , /home/appuser/tomcat7-MIR-/logs/localhost_access_log.--.txt (deleted)
java root 8w REG , /home/appuser/tomcat7-IMR-/logs/localhost.--.log (deleted)
java root 7w REG , /home/appuser/tomcat7-MIR-/logs/catalina.--.log (deleted)
java root 8w REG , /home/appuser/tomcat7-MIR-/logs/localhost.--.log (deleted)
java root 1w REG , /home/appuser/tomcat7-SI-/logs/catalina.out (deleted)
java root 2w REG , /home/appuser/tomcat7-SI-/logs/catalina.out (deleted)
果然存在未释放资源。一个占用了25981280125 大约24G,一个占用了 12643031059 大约12G,这不就是占满了嘛!而且都是catalina.out 日志文件
验证该文件是否存在:
[root@xxxx ~]# ll /home/appuser/tomcat7-MIR-/logs/catalina.out
-rw-r--r-- root root 4月 : /home/appuser/tomcat7-MIR-/logs/catalina.out
文件居然存在的,但是没那么大啊。
再看其他文件:
[root@xxxx ~]# ll /home/appuser/tomcat7-SI-/logs/catalina.out
ls: 无法访问/home/appuser/tomcat7-SI-/logs/catalina.out: 没有那个文件或目录
这个文件倒是真的不存在。
那么能通过创建文件的方式解决吗?
[root@xxxx ~]# > /home/appuser/tomcat7-SI-/logs/catalina.out
[root@xxxx ~]# ll /home/appuser/tomcat7-SI-/logs/catalina.out
-rw-r--r-- root root 4月 : /home/appuser/tomcat7-SI-/logs/catalina.out
[root@xxxx ~]# lsof -n | grep deleted
java root 1w REG , /home/appuser/tomcat7-MIR-/logs/catalina.out (deleted)
java root 2w REG , /home/appuser/tomcat7-MIR-/logs/catalina.out (deleted)
java root 8w REG , /home/appuser/tomcat7-MIR-/logs/localhost.--.log (deleted)
java root 42w REG , /home/appuser/tomcat7-MIR-/logs/localhost_access_log.--.txt (deleted)
java root 8w REG , /home/appuser/tomcat7-IMR-/logs/localhost.--.log (deleted)
java root 7w REG , /home/appuser/tomcat7-MIR-/logs/catalina.--.log (deleted)
java root 8w REG , /home/appuser/tomcat7-MIR-/logs/localhost.--.log (deleted)
java root 1w REG , /home/appuser/tomcat7-SI-/logs/catalina.out (deleted)
java root 2w REG , /home/appuser/tomcat7-SI-/logs/catalina.out (deleted))
创建文件并不能释放资源。
清空文件呢?
[root@xxxx ~]# > /home/appuser/tomcat7-MIR-/logs/catalina.out
[root@xxxx ~]# ll /home/appuser/tomcat7-MIR-/logs/catalina.out
-rw-r--r-- root root 4月 : /home/appuser/tomcat7-MIR-/logs/catalina.out
[root@xxxx ~]# lsof -n | grep deleted
java root 1w REG , /home/appuser/tomcat7-MIR-/logs/catalina.out (deleted)
java root 2w REG , /home/appuser/tomcat7-MIR-/logs/catalina.out (deleted)
java root 8w REG , /home/appuser/tomcat7-MIR-/logs/localhost.--.log (deleted)
java root 42w REG , /home/appuser/tomcat7-MIR-/logs/localhost_access_log.--.txt (deleted)
java root 8w REG , /home/appuser/tomcat7-IMR-/logs/localhost.--.log (deleted)
java root 7w REG , /home/appuser/tomcat7-MIR-/logs/catalina.--.log (deleted)
java root 8w REG , /home/appuser/tomcat7-MIR-/logs/localhost.--.log (deleted)
java root 1w REG , /home/appuser/tomcat7-SI-/logs/catalina.out (deleted)
java root 2w REG , /home/appuser/tomcat7-SI-/logs/catalina.out (deleted))
清空文件也不能释放资源。
正常来说直接把进程杀了,资源立刻就能被释放。但是这是生产环境,问了开发人员进程不能杀,那怎么办呢?
最彻底的方法当然就是重启进程,杀进程或重启服务器。但是不能杀的情况下,怎么释放资源呢?
当linux打开一个文件的时候,Linux内核会为每一个进程在/proc 目录下创建建立一个以其pid
为名的目录用来保存进程的相关信息,而其子目录fd保存的是该进程打开的所有文件的fd(fd:file descriptor)。
目录格式类似/proc/27319/fd
那么我们进到目录下,看有哪些文件被占用:
[root@xxxx fd]# cd /proc//fd
[root@xxxx fd]# ls [root@xxxx fd]# ll | grep deleted
l-wx------ root root 4月 : -> /home/appuser/tomcat7-MIR-/logs/catalina.out (deleted)
l-wx------ root root 4月 : -> /home/appuser/tomcat7-MIR-/logs/catalina.out (deleted)
l-wx------ root root 4月 : -> /home/appuser/tomcat7-MIR-/logs/localhost_access_log.--.txt (deleted)
l-wx------ root root 4月 : -> /home/appuser/tomcat7-MIR-/logs/localhost.--.log (deleted)
果然文件都是以链接的形式存在的,那么我们查看文件
/home/appuser/tomcat7-MIR-20012/logs/catalina.out
就相当于读取的这里的文件 1
文件1能直接查看吗?
[root@xxxx fd]# more
-- :: [cn.sh.xxx.mir.local.rule.allocation.impl.DefautAllocationRule]-[INFO] 技能组:3600上没有空闲的坐席!
-- :: [cn.sh.xxx.mir.local.executor.AllocationTask]-[INFO] 开始分配任务,队列: 任务数: 空闲坐席:
[root@xxxx fd]# tail
-- :: [cn.sh.xxx.mir.local.executor.AllocationTask]-[INFO] 开始分配任务,队列: 任务数: 空闲坐席:
-- :: [cn.sh.xxx.mir.local.rule.allocation.impl.AbstractAllocationRule]-[INFO] 获取租户514000技能队列3600上签入的坐席数据!
-- :: [cn.sh.xxx.mir.local.rule.allocation.impl.DefautAllocationRule]-[INFO] 技能组:3600上没有空闲的坐席!
-- :: [cn.sh.xxx.mir.local.executor.AllocationTask]-[INFO] 开始分配任务,队列: 任务数: 空闲坐席:
-- :: [cn.sh.xxx.mir.local.rule.allocation.impl.AbstractAllocationRule]-[INFO] 获取租户514000技能队列3650上签入的坐席数据!
-- :: [cn.sh.xxx.mir.local.rule.allocation.impl.DefautAllocationRule]-[INFO] 技能组:3650上没有空闲的坐席!
-- :: [cn.sh.xxx.mir.local.executor.AllocationTask]-[INFO] 开始分配任务,队列: 任务数: 空闲坐席:
-- :: [cn.sh.xxx.mir.local.rule.allocation.impl.AbstractAllocationRule]-[INFO] 获取租户514000技能队列3490上签入的坐席数据!
-- :: [cn.sh.xxx.mir.local.rule.allocation.impl.DefautAllocationRule]-[INFO] 技能组:3490上没有空闲的坐席!
-- :: [cn.sh.xxx.mir.local.executor.AllocationTask]-[INFO] 开始分配任务,队列: 任务数: 空闲坐席:
果然能直接查看,而且保留了2016年的日志,怪不得这么大。而且仍在往里面写日志。
再检查我们刚才创建的文件,日志并没写进去。
既然如此,那我们把这个日志文件清理了,空间时不时就降下来了?
[root@xxxx fd]# >
[root@xxxx ]# df -h
Filesystem Size Used Avail Use% Mounted on
/dev/xvda2 40G .4G 31G % /
tmpfs .8G .8G % /dev/shm
/dev/xvda1 190M 46M 135M % /boot
/dev/xvda3 40G 15G 23G % /home
/dev/xvda5 40G 49M 38G % /tmp
空间顺利释放,同样办法我们把另一个日志也清理掉。
java root 1w REG , /home/appuser/tomcat7-SI-/logs/catalina.out (deleted) [root@xxxx ]# cd /proc//fd
[root@xxxx fd]# ls -l | grep deleted
l-wx------ root root 4月 : -> /home/appuser/tomcat7-SI-/logs/catalina.out (deleted)
l-wx------ root root 4月 : -> /home/appuser/tomcat7-SI-/logs/catalina.out (deleted)
[root@xxxx fd]# >
[root@xxxx fd]# lsof -n | grep deleted
java root 1w REG , /home/appuser/tomcat7-MIR-/logs/catalina.out (deleted)
java root 2w REG , /home/appuser/tomcat7-MIR-/logs/catalina.out (deleted)
java root 8w REG , /home/appuser/tomcat7-MIR-/logs/localhost.--.log (deleted)
java root 42w REG , /home/appuser/tomcat7-MIR-/logs/localhost_access_log.--.txt (deleted)
java root 8w REG , /home/appuser/tomcat7-IMR-/logs/localhost.--.log (deleted)
java root 7w REG , /home/appuser/tomcat7-MIR-/logs/catalina.--.log (deleted)
java root 8w REG , /home/appuser/tomcat7-MIR-/logs/localhost.--.log (deleted)
java root 1w REG , /home/appuser/tomcat7-SI-/logs/catalina.out (deleted)
java root 2w REG , /home/appuser/tomcat7-SI-/logs/catalina.out (deleted)
[root@xxxx fd]# df -h
Filesystem Size Used Avail Use% Mounted on
/dev/xvda2 40G .4G 31G % /
tmpfs .8G .8G % /dev/shm
/dev/xvda1 190M 46M 135M % /boot
/dev/xvda3 40G .5G 35G % /home
/dev/xvda5 40G 49M 38G % /tmp
完成!
通过以上方法,在不杀进程的情况下,顺利释放了磁盘空间。但这只是一个临时的处理方式。
该文件不释放仍会持续增长下去。
仍然需要项目组预约一个维护窗口,把所有进程都杀掉,彻底释放资源才算彻底解决。
参考:
https://www.cnblogs.com/xxdfly/p/6564294.html
https://blog.csdn.net/wyzxg/article/details/4971843
Linux 不杀进程的情况下,如何释放磁盘资源的更多相关文章
- MySQL删除数据几种情况以及是否释放磁盘空间【转】
MySQL删除数据几种情况以及是否释放磁盘空间: 1.drop table table_name 立刻释放磁盘空间 ,不管是 Innodb和MyISAM ; 2.truncate table tabl ...
- Linux开启SELinux的情况下怎么解决nginx403跟502错误
https://www.cnblogs.com/caijt/p/10978324.html 以上篇博客中说了怎么在linux部署asp.net core 跟 nginx,里面成功的前提是把SElin ...
- Linux不重启的情况下添加硬盘
众所周知,SATA和SCSI是支持热插拔的,但是新装了这类支持热插拔的驱动器,系统不会马上识别的,往往我们需要重启系统来识别,但是有另外一种方法可以很方面的让系统识别新的设备.作为系统管理员,需要了解 ...
- Kali Linux ——在无网络情况下安装无线网卡驱动
1.背景: 今日刚刚开始学习kali linux,众所周知,安装完成后,系统是没有无线网卡驱动的,这就对学生党造成相当的困扰:校园网要连接有线是需要认证客户端的,而认证客户端只有windows端,如此 ...
- linux 无外网情况下安装 mysql
由于工作需要,需要在一台装有 CentOS 系统的测试服务器上安装 MySQL ,由于该服务器上存有其他比较重要的测试数据,所以不能连接外网.由于之前安装 MySQL 一直都是使用 yum 命令一键搞 ...
- Linux查看端口占用情况,并强制释放占用的端口
1.查找被占用的端口 netstat -tln netstat -tln | grep 8080 netstat -tln 查看端口使用情况,而netstat -tln | grep 8080则是只查 ...
- linux在不关机情况下新增硬盘的方法
开机状态插入硬盘 不关机执行命令 echo "- - -" > /sys/class/scsi_host/host0/scan 注意 echo "- - -&quo ...
- linux服务器没网情况下手动安装软件几个方法
1,找到一个有网的服务器,使用yumdownloader gcc,获取需要的rmp包: 2,在http://pkgs.org 下下载所需要的rpm包
- Linux在丢失的情况下重置密码
1.开机菜单是 移动光标到第一行 --敲击e 2.找到UTF-8,加上空格rd.break,敲击ctrl+x 3.输入以下命令 mount -o remount,rw /sysroot chroot ...
随机推荐
- 转:Linux中tomcat服务成功发布但局域网浏览器无法访问
转自:http://blog.csdn.net/mooncom/article/details/53168143 昨天,我在搭建Linux中服务器环境时,碰见一个问题,这里和大家分享一下. 问题描述: ...
- Java设计模式—备忘录模式
个人感觉备忘录模式是一个比较难的设计模式,备忘录模式就是一个对象的备份模式,提供了一种程序数据的备份方法. 定义如下:在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态.这样以 ...
- Android BitmapFactory.Options
public Bitmap inBitmap 如果设置,解码选项“对象的方法,采取将尝试重用这个位图加载内容时. public int inDensity 使用的位图的象素密度. public boo ...
- 模板继承and自定义模板标签和过滤器
自定义模板标签和 过滤器: 因为模板标签和过滤器只给我们提供了 这么多 无法对我们的使用造成更多的便利 ,剩下的就需要我们自己去创建新的 模板标签和过滤器了 1.在settings中的INSTALLE ...
- iOS设计模式 - 原型
iOS设计模式 - 原型 原理图 说明 1. 原型模式指的是从一个已有的对象复制并创建出新的对象 2. 当一个类的实例之间存在差异,而这些差异仅是状态的若干组合,复制原型要比手工实例化更加方便 3. ...
- HTML简单框架网页制作 吴昊
- Linux操作NFS挂载、卸载等操作
一.NFS服务器的设置 NFS服务器的设定可以通过/etc/exports这个文件进行,设定格式如下 分享目录 主机名或IP(参数1,参数2) /binbin 172.17.1.*(rw,sync,n ...
- Python学习---Python数据类型1206
1.1. 字符串格式化 字符格式化输出 占位符 %s s = string %d d = digit 整数 %f f = float 浮点数,约等于小数 #version: python3.2 ...
- Java实例---flappy-bird实例[最终版]
代码分析 解析版: Java实例---flappy-bird实例解析 完整版: TestBirdFly.java package testfly; import java.awt.Color; imp ...
- Skype for Business 安装组件RewriteModule失败
最近QQ网友提到部署Skype for Business,安装组件时提示安装必备组件失败:RewriteModule,如下图,安装文件名是rewrite_2.0_rtw_x64.msi,尝试手动安装也 ...