當系統空間使用量過大需要清理空間或者清理某個檔案時,有時會出現執行了刪除命令之後磁碟空間並沒有釋放,很多人首次遇到該情況時會比較困惑,在考慮是不是像windows系統的回收站一樣,刪除只是邏輯刪除到回收站一樣?其實不然,linux的回收站功能想了解的可以與我溝通或查資料瞭解一下,也是個比較實用的方法,此處我們主要實踐檔案刪除後空間未釋放問題。
1、 實驗準備
想模擬該場景的方式很多,主要是實現檔案被佔用的場景。最簡單的方式是拷貝檔案,另一個常見方式是對於會程式設計或shell功底較好的同學可以寫程式或指令碼不停的往一個檔案裡寫入內容。本次主要通過拷貝檔案來快速復現。
1.1 建立一個稍微大一點的檔案
/* 主要針對此檔案操作 */ [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 on devtmpfs 1.9G 0 1.9G 0% /dev tmpfs 1.9G 0 1.9G 0% /dev/shm tmpfs 1.9G 12M 1.9G 1% /run tmpfs 1.9G 0 1.9G 0% /sys/fs/cgroup /dev/mapper/centos-root 46G 6.5G 39G 15% / /dev/sda1 1014M 150M 865M 15% /boot tmpfs 378M 0 378M 0% /run/user/0
1.2 通過scp命令 佔用該檔案
/* 開始遠端拷貝至其他主機 */ [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)? yes Warning: 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 刪除檔案
此時刪除 檔案,再檢視檔案是否被刪除,空間是否釋放
/* 刪除檔案 */ [root@c7_2 local]# rm -f all_backup.tar.gz /* 檢視磁碟空間,沒有變化 */ [root@c7_2 local]# df -lh Filesystem Size Used Avail Use% Mounted on devtmpfs 1.9G 0 1.9G 0% /dev tmpfs 1.9G 0 1.9G 0% /dev/shm tmpfs 1.9G 12M 1.9G 1% /run tmpfs 1.9G 0 1.9G 0% /sys/fs/cgroup /dev/mapper/centos-root 46G 6.5G 39G 15% / /dev/sda1 1014M 150M 865M 15% /boot tmpfs 378M 0 378M 0% /run/user/0 /* 檔案已不在 */ [root@c7_2 local]# ll -h total 3.0G drwxr-xr-x. 2 root root 6 Apr 11 2018 bin drwxr-xr-x. 2 root root 6 Apr 11 2018 etc drwxr-xr-x. 2 root root 6 Apr 11 2018 games drwxr-xr-x. 2 root root 6 Apr 11 2018 include drwxr-xr-x. 2 root root 6 Apr 11 2018 lib drwxr-xr-x. 2 root root 6 Apr 15 05:56 lib64 drwxr-xr-x. 2 root root 6 Apr 11 2018 libexec drwxr-xr-x. 2 root root 6 Apr 11 2018 sbin drwxr-xr-x. 5 root root 49 Nov 17 16:46 share drwxr-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 deleted firewalld 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 1798 root 1798 1729 0 17:47 pts/0 00:00:00 scp all_backup.tar.gz test@192.168.28.226:/home/test root 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/test root 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 on devtmpfs 1.9G 0 1.9G 0% /dev tmpfs 1.9G 0 1.9G 0% /dev/shm tmpfs 1.9G 12M 1.9G 1% /run tmpfs 1.9G 0 1.9G 0% /sys/fs/cgroup /dev/mapper/centos-root 46G 4.0G 42G 9% / /dev/sda1 1014M 150M 865M 15% /boot tmpfs 378M 0 378M 0% /run/user/0
注: 如果是持續寫入日誌的想清空日誌等情況,可以使用 echo " ">filename 命令線上清空該檔案,無需暴力的結束程式,如果此方法無效時再考了結束程式。
3、結語
本文主要適用於以下場景:
- 刪除檔案空間未釋放
- 磁碟滿了 但是找不到檔案
再提示一遍,如果可以使用 echo " ">filename 命令線上清空檔案,則無需暴力的結束程式,如果此方法無效時再考了結束程式。
如想了解更多精彩文章或進入技術群,可以關注wx公眾號 資料庫乾貨鋪