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 ...
随机推荐
- 微服务架构之spring cloud feign
在spring cloud ribbon中我们用RestTemplate实现了服务调用,可以看到我们还是需要配置服务名称,调用的方法 等等,其实spring cloud提供了更优雅的服务调用方式,就是 ...
- ButterKnife 初体验
ButterKnife 环境搭建 在project的build.gradle文件中添加依赖的插件 //ButterKnife 的插件 // classpath 'com.jakewharton:but ...
- 没有对比就没有伤害,memcache and redis
Memcached 与 Redis 的关键性能指标比较 性能对比: Redis 只使用单核,而 Memcached 可以使用多核,所以平均每一个核上 Redis在存储小数据时比 Memcached 性 ...
- Sqlserver函数基础使用
函数基本功能: 转换工厂日期,将8点20之前的时间转化为前一天的时间. if exists (select * from sysobjects where xtype='fn' and name='F ...
- SQL一次性查询一个字段不同条件下的统计结果
参考了一下这篇文章:https://blog.csdn.net/xichenguan/article/details/51764100 , 感谢原作者 有两个表,分别存放了[操作员]和[单据],要根据 ...
- P2DR模型
P2DR模型是可适应网络安全理论或称为动态信息安全理论的主要模型.P2DR模型是TCSEC模型的发展,也是目前被普遍采用的安全模型.P2DR模型包含四个主要部分:Policy(安全策略).Protec ...
- Python学习---Java和Python的区别小记
Java和Python的区别小记 注意这里使用的是 and/or/not 非java中的&&,||,!Java中的true是小写 Python中函数就是对象,函数和我们之前的[1,2 ...
- SQL Server系统常用存储过程
SQL Server系统存储过程也是好几百个,算了,还是写几个常用的. 1.sp_help 查询表的信息 执行存储过程: sp_help Person 显示结果如下: 妈了个B,有了这张图,你还不懂怎 ...
- Eclipse PHPEclipse 配置
最近偶来兴致趁着有些时间,看了看php的书. 说到php就不得不提php的开发环境了,一般的都是采用apache做服务器.mysql做数据库,再加上php组合成一个完备的运行环境,但是好像没有写代码的 ...
- scala当中的特质trait
1.将trait作为接口使用 Scala中的trait是一种特殊的概念: 首先先将trait作为接口使用,此时的trait就与Java中的接口 (interface)非常类似: 在trait中可以定义 ...