linux連個文件都刪除不了,什麼鬼!

前言

最近不是redis 6.0 出了嗎,官網介紹最新穩定版本是 6.0.3 。於是,我就準備在自己的破小服務器上安裝一下。於是,出現了後續的糟心事 (linux 下的文件正常刪除不了)。

下載了最新版本,在源碼包裡邊 make 之後,出現了好幾個錯誤,上網查了下,有人說最新版本有問題,建議使用 5.0.8 。我嘞個去,我想也沒想就相信了。(其實,也有可能跟我的系統沒安裝 tcl 有關係,這就是後話了)

然後,我就下載了 5.0.8 版本的redis,重新安裝。

發現問題

從官網下載了 5.0.8 的源碼包之後,就從我本地(win系統)通過 scp 命令上傳到服務器。如下,

由於源碼包下載到了桌面位置,因此本地路徑的地址就寫的絕對路徑 「C:\ …」 ,上傳到遠程服務器的 /root 目錄下。誰成想到了服務器上的文件名是這個樣子。如下,

文件名竟然把本地文件的路徑也帶上了。這就讓人很頭疼了,我想着,就把它重新命名一下吧。

這麼長的文件名,我肯定複製粘貼啊。但是粘貼之後發現 linux 下把前邊當成一個路徑來解析了,按照的是 linux 下文件夾的路徑格式(windows的文件分隔符為反斜杠”\”,linux下為”/”),如下,

很明顯,在linux下默認是沒有根路徑為 “/c” 這樣的路徑的。因此,就報錯沒有找到該目錄。

這就讓人很 dan 疼了,重命名不行,那就嘗試下刪除吧,大不了我重新上傳文件就是了。

但是,結果也並不如我所願, 執行刪除命令之後,文件還在,

原因,我猜測也是和重命名一樣,linux 把文件名解析為路徑了。然後看到網上說,給文件名加引號可以避免這種情況,我就操作了一番,並刻意地手打原文件的名字。(原為反斜杠)

然而並沒有什麼用,怎樣都繞不過它把這個文件名當成路徑來解析。。。

解決問題

後來,還是群里的小夥伴給我的解決方案,真是 tql 。遂記錄如下,

解決鏈接://www.askcto.com/searchInfo?qId=7056cab522d84d0eb9c1a36eba66b324

思路就是,通過文件索引節點號來刪除,繞過文件名。先通過 ls -i,顯示所有文件索引節點號(如下,目標文件的索引節點號為 477536),然後通過索引節點號來刪除文件。

文件索引節點號

那麼,有的童鞋就會問了,什麼是文件索引節點號呢?

在這之前需要了解一下 linux 中文件的存儲形式,以及文件索引節點。

在 linux 下,文件在磁盤上的存儲是以「塊」為單位的,「塊」是文件的最小存儲單元。每個塊又包含多個扇區,每個扇區大小為 512 位元組。通常 8 個扇區組成一個「塊」。

由於文件的數據都存儲在「塊」中,因此我們還需要找到一塊區域來保存文件的元信息,包括文件的權限,擁有者,大小,以及存儲的位置。而這樣的區域就叫做文件索引節點(inode)

元信息可以理解為是用來保存文件相關信息的信息。可以拿 Java 中的元註解來類比(元註解就是用來標註註解的註解)。

每個 inode 都有一個號碼,這個就叫做文件索引節點號。操作系統最終是通過文件索引節點號來識別不同的文件的,而不是通過文件名。

如下圖,可以通過 stat 命令打印出一個文件(以 TankServer.zip為例)的 inode 所有元信息,還有 inode 號。

文件名和文件索引節點號之間的關係,有點類似於域名和 IP 之間的映射關係。

比如訪問百度,我們只會記得它的域名為”www.baidu.com”,並不會去記它的 IP 地址是多少,而且 IP 對我們來說也不好記。這就好比,我們程序員只用記文件名,而不知道它的文件索引節點號一樣。

但是實際上,最終還是需要域名解析器 DNS 把域名解析為具體的 IP 地址(此處不考慮CDN),才能讓其他服務器識別。這就好比,linux 系統最終只會通過文件索引節點號來識別文件。

說了這麼多,其實我們只是想知道當前需要刪除文件的文件索引節點號而已。既然不能通過文件名刪除,我直接越過你,找到對應的文件索引節點號不就可以了(相當於,我如果知道百度的 IP 地址,可以直接通過 IP 訪問)。

PS:更多關於 inode 的介紹,可以參考阮一峰老師的博客://www.ruanyifeng.com/blog/2011/12/inode.html

刪除命令

那麼知道了文件索引節點號,我們就可以通過以下的格式來刪除它對應的文件。

find ./ -inum inode號 -exec rm {} \;

前半部分,find 命令是在當前目錄下找到 inode 號對應的文件。後半部分 -exec 表示查找後緊跟着要執行的命令。rm 就是刪除文件的命令。刪除哪個文件呢,{} 作用就是把 find 的結果作為參數傳給 -exec 。

最後還要注意, 使用 -exec 參數,需要用 ; 分號結尾,不然會報錯如下圖。 而 “\”反斜杠是為了轉義分號。

結語

以上就是在 linux 中刪除文件時遇到的坑。若你遇到類似的問題,或者出現了某個文件名中有特殊字符導致刪除不了文件,也可以嘗試一下以上的操作方式哦。

溫馨提示: 刪除文件時,一定要小心哦,別最後刪庫跑路了!

我剛才測試時,就在 inum 前少加了橫杠 (正確應該為 -inum)。導致整個命令刪除了其它目錄文件,如下圖。

幸好這是個目錄文件,也幸好我沒用 rm -rf 遞歸刪除文件,要不然,這個文件夾就廢了。下邊繼續執行下去,還要刪除 npm,天知道最後會不會把系統文件也刪了。

幸好我手快,及時 Ctrl + C 了(單身二十多年的手速可不是白練的~)。

若本文對你有用,歡迎關注我,給我點贊哦 ~

Tags: