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 ...
随机推荐
- JS 对html标签的属性的干预以及JS 对CSS 样式表属性的干预
-任何标签的任何属性都可以修改! -HTML里是怎么写, JS就怎么写 以下是一段js 作用于 css 的 href的 代码 <link id="l1" rel= ...
- Web开发须知的浏览器内幕 缓存与存储篇(2)
本文禁止转载,由UC浏览器内部出品. 3. HTTP Cache 综述 HTTP Cache是完全按照IETF规范实现的,最新的RFC规范地址是 https://tools.ietf.org/html ...
- Excel 2016 for Mac
1. Excel for Mac 的 Developer tab下没有XML组,因此无法从xml导入或者导出到xml: 2. Excel for Mac 中没有Mark as Finnal的功能: 3 ...
- C++创建一个新的进程
原文:http://blog.csdn.net/hk627989388/article/details/53309865 STARTUPINFO用于指定新进程的主窗口特性的一个结构. PROCESS_ ...
- Android实时获得经纬度,发送给c++服务端
Android 客户端: package com.example.admin.gpsget; import android.Manifest; import android.content.Conte ...
- python django 环境搭建
一. 版本选择 Django 1.5.x 支持 Python 2.6.5 Python 2.7, Python 3.2 和 3.3. Django 1.6.x 支持 Python 2.6.X, 2.7 ...
- 数据库常用SQL用法
查找某列数据包含某一字符串: SELECT * FROM table WHERE column LIKE '%string%' 查找某列数据以某些字符串开头: SELECT * FROM table ...
- configparser logging collections 模块
configparser 模块: 这是一个写入的模块就是把你的信息给写入的模块 #这是一个把信息写入example文件内import configparserconfig = configparser ...
- SCCM2007日志文件
Microsoft System Center Configuration Manager 2007 中的所有客户端和站点服务器组件都将过程信息记录在单个日志文件中.您可以使用客户端和站点服务器日志文 ...
- 计算机应用基础教程作业flash动画 车辆工程 冯大昕