解決linux下刪除檔案或oracle表空間後空間不釋放的問題
在linux下刪除檔案或oracle表空間後,很多人會遇到linux空間不釋放的問題,這個問題可以如下解決:[@more@]
用root使用者登陸
執行命令: lsof | grep 你要刪除的作業系統檔名
就會看到類似如下資訊:
oracle 15435 oracle 7u REG 8,6 0 57871108 /test.dbf (deleted)
說明作業系統正在進行刪除的清理工作,
把所有(delete)狀態的都kill掉,注意這裡面有一些oracle資料庫自身的程式的不要kill,然後等三分鐘,空間就釋放出來了.附lsof命令的用法:
lsof(list open files)是一個列出當前系統開啟檔案的工具。在linux環境下,任何事物都以檔案的形式存在,透過檔案不僅僅可以訪問常規資料,還可以訪問網路連線和硬體。所以如傳輸控制協議 (TCP) 和使用者資料包協議 (UDP) 套接字等,系統在後臺都為該應用程式分配了一個檔案描述符,無論這個檔案的本質如何,該檔案描述符為應用程式與基礎作業系統之間的互動提供了通用介面。因為應用程式開啟檔案的描述符列表提供了大量關於這個應用程式本身的資訊,因此透過lsof工具能夠檢視這個列表對系統監測以及排錯將是很有幫助的。
在終端下輸入lsof即可顯示系統開啟的檔案,因為 lsof 需要訪問核心記憶體和各種檔案,所以必須以 root 使用者的身份執行它才能夠充分地發揮其功能。
COMMAND PID USER FD TYPE DEVICE SIZE NODE NAME init 1 root cwd DIR 3,3 1024 2 / init 1 root rtd DIR 3,3 1024 2 / init 1 root txt REG 3,3 38432 1763452 /sbin/init init 1 root mem REG 3,3 106114 1091620 /lib/libdl-2.6.so init 1 root mem REG 3,3 7560696 1091614 /lib/libc-2.6.so init 1 root mem REG 3,3 79460 1091669 /lib/libselinux.so.1 init 1 root mem REG 3,3 223280 1091668 /lib/libsepol.so.1 init 1 root mem REG 3,3 564136 1091607 /lib/ld-2.6.so init 1 root 10u FIFO 0,15 1309 /dev/initctl
每行顯示一個開啟的檔案,若不指定條件預設將顯示所有程式開啟的所有檔案。lsof輸出各列資訊的意義如下:
COMMAND:程式的名稱 PID:程式識別符號 USER:程式所有者 FD:檔案描述符,應用程式透過檔案描述符識別該檔案。如cwd、txt等 TYPE:檔案型別,如DIR、REG等 DEVICE:指定磁碟的名稱 SIZE:檔案的大小 NODE:索引節點(檔案在磁碟上的標識) NAME:開啟檔案的確切名稱
其中FD 列中的檔案描述符cwd 值表示應用程式的當前工作目錄,這是該應用程式啟動的目錄,除非它本身對這個目錄進行更改。
txt 型別的檔案是程式程式碼,如應用程式二進位制檔案本身或共享庫,如上列表中顯示的 /sbin/init 程式。其次數值表示應用
程式的檔案描述符,這是開啟該檔案時返回的一個整數。如上的最後一行檔案/dev/initctl,其檔案描述符為 10。u 表示該
檔案被開啟並處於讀取/寫入模式,而不是隻讀 ® 或只寫 (w) 模式。同時還有大寫 的W 表示該應用程式具有對整個檔案的寫
鎖。該檔案描述符用於確保每次只能開啟一個應用程式例項。初始開啟每個應用程式時,都具有三個檔案描述符,從 0 到 2,
分別表示標準輸入、輸出和錯誤流。所以大多數應用程式所開啟的檔案的 FD 都是從 3 開始。
與 FD 列相比,Type 列則比較直觀。檔案和目錄分別稱為 REG 和 DIR。而CHR 和 BLK,分別表示字元和塊裝置;
或者 UNIX、FIFO 和 IPv4,分別表示 UNIX 域套接字、先進先出 (FIFO) 佇列和網際協議 (IP) 套接字。
lsof 常見的用法是查詢應用程式開啟的檔案的名稱和數目。可用於查詢出某個特定應用程式將日誌資料記錄到何處,或者正在跟蹤某個問題。
例如,linux限制了程式能夠開啟檔案的數目。通常這個數值很大,所以不會產生問題,並且在需要時,應用程式可以請求更大的值(直到某
個上限)。如果你懷疑應用程式耗盡了檔案描述符,那麼可以使用 lsof 統計開啟的檔案數目,以進行驗證。lsof語法格式是:
lsof [options] filename
常用的引數列表:
lsof filename 顯示開啟指定檔案的所有程式 lsof -a 表示兩個引數都必須滿足時才顯示結果 lsof -c string 顯示COMMAND列中包含指定字元的程式所有開啟的檔案 lsof -u username 顯示所屬user程式開啟的檔案 lsof -g gid 顯示歸屬gid的程式情況 lsof +d /DIR/ 顯示目錄下被程式開啟的檔案 lsof +D /DIR/ 同上,但是會搜尋目錄下的所有目錄,時間相對較長 lsof -d FD 顯示指定檔案描述符的程式 lsof -n 不將IP轉換為hostname,預設是不加上-n引數 lsof -i 用以顯示符合條件的程式情況 lsof -i[46] [protocol][@hostname|hostaddr][:service|port] 46 --> IPv4 or IPv6 protocol --> TCP or UDP hostname --> Internet host name hostaddr --> IPv4地址 service --> /etc/service中的 service name (可以不只一個) port --> 埠號 (可以不只一個)
例如: 檢視22埠現在執行的情況
# lsof -i :22 COMMAND PID USER FD TYPE DEVICE SIZE NODE NAME sshd 1409 root 3u IPv6 5678 TCP *:ssh (LISTEN)
檢視所屬root使用者程式所開啟的檔案型別為txt的檔案:
# lsof -a -u root -d txt COMMAND PID USER FD TYPE DEVICE SIZE NODE NAME init 1 root txt REG 3,3 38432 1763452 /sbin/init mingetty 1632 root txt REG 3,3 14366 1763337 /sbin/mingetty mingetty 1633 root txt REG 3,3 14366 1763337 /sbin/mingetty mingetty 1634 root txt REG 3,3 14366 1763337 /sbin/mingetty mingetty 1635 root txt REG 3,3 14366 1763337 /sbin/mingetty mingetty 1636 root txt REG 3,3 14366 1763337 /sbin/mingetty mingetty 1637 root txt REG 3,3 14366 1763337 /sbin/mingetty kdm 1638 root txt REG 3,3 132548 1428194 /usr/bin/kdm X 1670 root txt REG 3,3 1716396 1428336 /usr/bin/Xorg kdm 1671 root txt REG 3,3 132548 1428194 /usr/bin/kdm startkde 2427 root txt REG 3,3 645408 1544195 /bin/bash ... ...
在解除安裝檔案系統時,如果該檔案系統中有任何開啟的檔案,操作通常將會失敗。那麼透過lsof可以找出那些程式在使用當前要解除安裝的檔案系統,如下:
# lsof /GTES11/ COMMAND PID USER FD TYPE DEVICE SIZE NODE NAME bash 4208 root cwd DIR 3,1 4096 2 /GTES11/ vim 4230 root cwd DIR 3,1 4096 2 /GTES11/
在這個示例中,使用者root正在其/GTES11目錄中進行一些操作。一個 bash是例項正在執行,並且它當前的目錄為/GTES11,另一個則顯示的是vim正在編輯/GTES11下的檔案。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/7490392/viewspace-1021354/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Linux檔案刪除但空間不釋放問題篇Linux
- 解決刪除檔案後 WSL2 磁碟空間不釋放的問題
- (轉載)刪除檔案後硬碟空間不釋放的問題硬碟
- 處理Linux刪除檔案後空間未釋放的問題Linux
- Linux檔案刪除空間未釋放Linux
- RM刪除檔案空間釋放詳解
- linux中如何解決檔案已刪除但空間不釋放的案例Linux
- [待整理]oracle10g刪除(釋放)資料檔案/表空間流程Oracle
- MySQL 5.7的表刪除資料後的磁碟空間釋放MySql
- oracle建立臨時表空間和資料表空間以及刪除Oracle
- Oracle 表空間增加檔案Oracle
- Mysql InnoDB刪除資料後釋放磁碟空間的方法MySql
- Oracle 刪除使用者、表空間、資料檔案、使用者下的所有表Oracle
- Tablespace表空間刪除
- oracle級聯刪除使用者,刪除表空間Oracle
- 刪除臨時表空間組
- 刪除UNDO表空間並處理ORA-01548問題
- Oracle表空間Oracle
- oracle 表空間Oracle
- 如何釋放Mac空間?釋放Mac系統空間小技巧Mac
- Oracle的表空間quota詳解Oracle
- Oracle臨時表空間檢視、新增臨時表空間資料檔案、修改預設臨時表空間 方法!Oracle
- 新建的表空間(或資料檔案)丟失以及控制檔案丟失,有新建表空間(或資料檔案)前的控制文
- 面試官給我挖坑:rm刪除檔案之後,空間就被釋放了嗎?面試
- oracle 普通表空間資料檔案壞塊Oracle
- Oracle 10g大檔案表空間(轉)Oracle 10g
- 臨時表空間ORA-1652問題解決
- oracle表空間的整理Oracle
- 增加oracle表空間Oracle
- oracle temp 表空間Oracle
- [20210528]oracle大表空間預分配問題.txtOracle
- oracle 臨時表空間的增刪改查Oracle
- SQLServer如何釋放tempdb臨時表空間SQLServer
- 為什麼問題空間與解決方案空間如此重要? - Nikhil Gupta
- 刪除檔案後儲存空間容量沒有變化怎麼辦?
- Oracle案例11——Oracle表空間資料庫檔案收縮Oracle資料庫
- oracle系統表空間過大問題處理Oracle
- Oracle 批量建表空間Oracle
- Oracle清理SYSAUX表空間OracleUX