Linux文件删除后空间未释放问题详解_Linux

来源:脚本之家  责任编辑:小易  

linux是虽然删除文件,其实只删除文件和系统目录结构的链接。那么如果有程序在读取这个文件,那么文件还是存在,没有删除掉文件出在在读取的状态,还是占用磁盘空间的,只有让程序不读取这个文件了,才能完整的释放文件所占用的空间,所以只有从其服务或杀死服务的进程才能完整地删除文件和释放磁盘空间www.zgxue.com防采集请勿采集本网。

前言

当系统空间使用量过大需要清理空间或者清理某个文件时,有时会出现执行了删除命令之后磁盘空间并没有释放,很多人首次遇到该情况时会比较困惑,在考虑是不是像windows系统的回收站一样,删除只是逻辑删除到回收站一样?其实不然,linux的回收站功能想了解的可以与我沟通或查资料了解一下,也是个比较实用的方法,此处我们主要实践文件删除后空间未释放问题。

系统中有进程正在使用该文件 这里给出两种解决方案: 温柔的: 1、用 lsof|grep-i deleted命令列出被删除但是依旧有进程在使用的文件 2、可以用kill命令杀掉这些进程 简单粗暴的: 重启系统

1、 实验准备

你用什么方式删除的文件?如果是用图形界面,而不是命令行,被删除的文件可能移动到了回收站当中。回收站所在的目录是\"~/.Trash。去这个文件夹下核查一下。如果使用的是命令行中的rm命令,使用“ls-al”

想模拟该场景的方式很多,主要是实现文件被占用的场景。最简单的方式是拷贝文件,另一个常见方式是对于会编程或shell功底较好的同学可以写程序或脚本不停的往一个文件里写入内容。本次主要通过拷贝文件来快速复现。

有些文件删除后并不一定通过df可以查看到 重启一下再试试df命令 如果重启后还是不行,那就是没删除多少东西。

1.1 创建一个稍微大一点的文件

确定是删除掉了么 用df-h看看是多少 然后再用du-sh* 一步一步的追溯下去,看看到底是哪个文件占用了你的空间

主要原因是:该文件还在被进程占用。解决办法:需要kill掉相关进程才能释放,或者重启主机。

/* 主要针对此文件操作 */[root@c7_2 local]# ll -h total 3.0G-rw-r--r--. 1 root root 2.5G May 4 17:43 all_backup.tar.gz/* 此时根目录使用量6.5G */[root@c7_2 ~]# df -lh Filesystem Size Used Avail Use% Mounted ondevtmpfs 1.9G 0 1.9G 0% /devtmpfs 1.9G 0 1.9G 0% /dev/shmtmpfs 1.9G 12M 1.9G 1% /runtmpfs 1.9G 0 1.9G 0% /sys/fs/cgroup/dev/mapper/centos-root 46G 6.5G 39G 15% //dev/sda1 1014M 150M 865M 15% /boottmpfs 378M 0 378M 0% /run/user/0

1.2 通过scp命令 占用该文件

主要原因是:该文件还在被进程占用。解决办法:需要kill掉相关进程才能释放,或者重启主机。

/* 开始远程拷贝至其他主机 */[root@c7_2 local]# scp all_backup.tar.gz test@192.168.28.226:/home/test/ The authenticity of host '192.168.28.226 (192.168.28.226)' can't be established.ECDSA key fingerprint is SHA256:QfJb1DogFmdZ0hkeVRvn2VHke+tkZ2+sNljhBBudooc.ECDSA key fingerprint is MD5:2a:8a:63:80:35:17:f7:e9:2a:ea:13:98:eb:26:30:ba.Are you sure you want to continue connecting (yes/no)? yesWarning: Permanently added '192.168.28.226' (ECDSA) to the list of known hosts.test@192.168.28.226's password: all_backup.tar.gz 0% 2432KB 2.4MB/s 17:53 ETA^Z[1]+ Stopped scp all_backup.tar.gz test@192.168.28.226:/home/test /* 放在后台运行 */[root@c7_2 local]# bg %1 [1]+ scp all_backup.tar.gz test@192.168.28.226:/home/test &

1.3  删除文件

主要原因是:该文件还在被进程占用。解决办法:需要kill掉相关进程才能释放,或者重启主机。

/* 删除文件 */[root@c7_2 local]# rm -f all_backup.tar.gz /* 查看磁盘空间,没有变化 */[root@c7_2 local]# df -lh Filesystem Size Used Avail Use% Mounted ondevtmpfs 1.9G 0 1.9G 0% /devtmpfs 1.9G 0 1.9G 0% /dev/shmtmpfs 1.9G 12M 1.9G 1% /runtmpfs 1.9G 0 1.9G 0% /sys/fs/cgroup/dev/mapper/centos-root 46G 6.5G 39G 15% //dev/sda1 1014M 150M 865M 15% /boottmpfs 378M 0 378M 0% /run/user/0/* 文件已不在 */[root@c7_2 local]# ll -h total 3.0Gdrwxr-xr-x. 2 root root 6 Apr 11 2018 bindrwxr-xr-x. 2 root root 6 Apr 11 2018 etcdrwxr-xr-x. 2 root root 6 Apr 11 2018 gamesdrwxr-xr-x. 2 root root 6 Apr 11 2018 includedrwxr-xr-x. 2 root root 6 Apr 11 2018 libdrwxr-xr-x. 2 root root 6 Apr 15 05:56 lib64drwxr-xr-x. 2 root root 6 Apr 11 2018 libexecdrwxr-xr-x. 2 root root 6 Apr 11 2018 sbindrwxr-xr-x. 5 root root 49 Nov 17 16:46 sharedrwxr-xr-x. 2 root root 6 Apr 11 2018 src

2、 处理方法

可以通过lsof (list opened files)命令查看已经打开的文件以及文件被哪个进程所占用。

lsof命令在最小化安装的系统中是没有,可以先通过yum安装

yum install -y lsof

2.1  lsof查看文件

查看所有已打开文件并筛选出其中已删除状态(deleted)的文件

[root@c7_2 local]# lsof |grep deletedfirewalld 818 root 6u REG 253,0 4096 36061750 /tmp/ffi0SEit6 (deleted)gmain 818 998 root 6u REG 253,0 4096 36061750 /tmp/ffi0SEit6 (deleted)tuned 1180 root 8u REG 253,0 4096 33554962 /tmp/ffio5Nu8r (deleted)gmain 1180 1602 root 8u REG 253,0 4096 33554962 /tmp/ffio5Nu8r (deleted)tuned 1180 1603 root 8u REG 253,0 4096 33554962 /tmp/ffio5Nu8r (deleted)tuned 1180 1605 root 8u REG 253,0 4096 33554962 /tmp/ffio5Nu8r (deleted)tuned 1180 1606 root 8u REG 253,0 4096 33554962 /tmp/ffio5Nu8r (deleted)scp 1798 root 3r REG 253,0 2665433605 104181296 /usr/local/all_backup.tar.gz (deleted)

发现了我们刚删除的文件以及被那个进程所打开

2.2  查看进程

通过lsof发现了all_backup.tar.gz 文件被1798 号进程所占用,可以查看该进程具体是什么

[root@c7_2 local]# ps -ef|grep 1798root 1798 1729 0 17:47 pts/0 00:00:00 scp all_backup.tar.gz test@192.168.28.226:/home/testroot 1799 1798 2 17:47 pts/0 00:00:03 /usr/bin/ssh -x -oForwardAgent=no -oPermitLocalCommand=no -oClearAllForwardings=yes -l test -- 192.168.28..226 scp -t /home/testroot 1868 1806 0 17:49 pts/1 00:00:00 grep --color=auto 1798

正是我们之前执行的拷贝命令

2.3 释放空间

对于此种查询状态情况,需要结束对应程序

/* 杀掉对应进程 */[root@c7_2 local]# kill -9 1799 1798/* 空间已释放 */[root@c7_2 local]# df -lh Filesystem Size Used Avail Use% Mounted ondevtmpfs 1.9G 0 1.9G 0% /devtmpfs 1.9G 0 1.9G 0% /dev/shmtmpfs 1.9G 12M 1.9G 1% /runtmpfs 1.9G 0 1.9G 0% /sys/fs/cgroup/dev/mapper/centos-root 46G 4.0G 42G 9% //dev/sda1 1014M 150M 865M 15% /boottmpfs 378M 0 378M 0% /run/user/0

注: 如果是持续写入日志的想清空日志等情况,可以使用 echo " ">filename 命令在线清空该文件,无需暴力的结束进程,如果此方法无效时再考了结束进程。

3、结语

本文主要适用于以下场景: 删除文件空间未释放 磁盘满了 但是找不到文件

再提示一遍,如果可以使用 echo " ">filename 命令在线清空文件,则无需暴力的结束进程,如果此方法无效时再考了结束进程。

到此这篇关于Linux文件删除后空间未释放问题的文章就介绍到这了,更多相关Linux文件删除空间未释放内容请搜索真格学网以前的文章或继续浏览下面的相关文章希望大家以后多多支持真格学网!

一般来说不会出现删除文件后空间不释放的情况,但是也存在例外,比如文件被进程锁定,或者有进程一直在向这个文件写数据等,要理解这个问题,就需要知道Linux下文件的存储机制和存储结构。一个文件在文件系统中的存放分为两个部分:数据部分和指针部分,指针位于文件系统的meta-data中,在将数据删除后,这个指针就从meta-data中清除了,而数据部分存储在磁盘中。在将数据对应的指针从meta-data中清除后,文件数据部分占用的空间就可以被覆盖并写入新的内容,之所以在出现删除access_log文件后,空间还没释放,就是因为httpd进程还在一直向这个文件写入内容,导致虽然删除了access_log文件,但是由于进程锁定,文件对应的指针部分并未从meta-data中清除,而由于指针并未删除,系统内核就认为文件并未删除,因此通过df命令查询空间并未释放也就不足为奇了。通过这个命令可以获取一个仍然被应用程序占用的已删除文件列表,命令执行如下:[root@localhost~]#lsof|grep delete最好的方法是在线清空这个文件,具体可以通过如下命令完成:[root@localhost~]#echo"">/tmp/acess.log内容来自www.zgxue.com请勿采集。


  • 本文相关:
  • linux如何处理文件已删除但空间不释放的问题
  • 手动释放linux服务器内存(具体操作步骤)
  • linux强制释放占用端口以及linux防火墙端口开放方法详解
  • cckiller:linux轻量级cc攻击防御工具,秒级检查、自动拉黑和释放
  • linux 内存清理/释放命令总结
  • linux 内存释放命令详解
  • 详解linux手动释放缓存的方法
  • 详解linux 驱动编写(sd卡驱动)
  • linux io多路复用之epoll网络编程
  • linux中禁止用户修改/重置密码
  • linux vps主机上备份网站和数据库的方法
  • centos 6和centos 7下服务启动方法及添加到开机启动项的方法
  • centos7 mysql数据库安装和配置
  • linux与windows xp之间使用ftp互传文件
  • 正确配置与维护apache安全性设置方法
  • 详解linux系统输入输出管理和vim的常用功能
  • 解决ubuntu19 安装theano问题
  • linux中如何解决文件已删除但空间不释放的案例?
  • 如何解决Linux系统文件已删除但空间未释放
  • linux删除文件后空间没有释放问题?
  • 如何解决Linux系统文件已删除但空间未释放的情况
  • 如何解决Linux系统文件已删除但空间未释放的情况
  • linux下删除文件后空间没释放
  • linux系统删除大量文件后,硬盘空间怎么还是满的,没有释放空间?
  • linux删除文件后空间无法释放?lsof没有结果。重启无效。请问各位高手还有别的办法吗?
  • linux下为什么删除了文件空间却不释放
  • linux rm删除任何文件,空间都不释放
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全星外虚拟主机华众虚拟主机linuxwin服务器ftp服务器dns服务器tomcat nginxzabbix云和虚拟化服务器其它首页服务器linuxlinux如何处理文件已删除但空间不释放的问题手动释放linux服务器内存(具体操作步骤)linux强制释放占用端口以及linux防火墙端口开放方法详解cckiller:linux轻量级cc攻击防御工具,秒级检查、自动拉黑和释放linux 内存清理/释放命令总结linux 内存释放命令详解详解linux手动释放缓存的方法详解linux 驱动编写(sd卡驱动)linux io多路复用之epoll网络编程linux中禁止用户修改/重置密码linux vps主机上备份网站和数据库的方法centos 6和centos 7下服务启动方法及添加到开机启动项的方法centos7 mysql数据库安装和配置linux与windows xp之间使用ftp互传文件正确配置与维护apache安全性设置方法详解linux系统输入输出管理和vim的常用功能解决ubuntu19 安装theano问题apache开启.htaccess及.htaccessservice temporarily unavailabllinux下实现免密码登录(超详细)apache rewrite url重定向功能的linux下用cron定时执行任务的方法apache性能测试工具ab使用详解centos 6.4安装配置lamp服务器(a阿里云服务器ping不通解决办法(centos+nginx+php+mysql详细配置apache you don""t have permisslinux安全设置之关于grub加密图文教程全解apache中使用mod_gnutls模块实现多个ssl站linux shell命令用法及常见用例之tar命令centos下fail2ban安装与配置详解详解linux下安装python3环境linux 为特定的用户或用户组启用或禁用 slinux环境下apache服务器配置二级域名的方linux在应用层读写寄存器的方法及实现实例在linux上识别同样内容的文件详解linux系统终端修改字体的方法
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved