Linux中國

Linux 下清空或刪除大文件內容的 5 種方法

注意:在我們進一步深入了解這些方法之前,請記住: 由於在 Linux 中一切皆文件,你需要時刻注意,確保你將要清空文件不是重要的用戶文件或者系統文件。清空重要的系統文件或者配置文件可能會引發嚴重的應用失敗或者系統錯誤。

前面已經說道,下面的這些方法都是從命令行中達到清空文件的目的。

提示:在下面的示例中,我們將使用名為 access.log 的文件來作為示例樣本。

1. 通過重定向到 Null 來清空文件內容

清空或者讓一個文件成為空白的最簡單方式,是像下面那樣,通過 shell 重定向 null (不存在的事物)到該文件:

# > access.log

Empty Large File Using Null Redirect in Linux

在 Linux 下使用 Null 重定向來清空大文件

2. 使用 『true』 命令重定向來清空文件

下面我們將使用 : 符號,它是 shell 的一個內置命令,等同於 true 命令,它可被用來作為一個 no-op(即不進行任何操作)。

另一種清空文件的方法是將 : 或者 true 內置命令的輸出重定向到文件中,具體如下:

# : > access.log
或 
# true > access.log

Empty Large File Using Linux Commands

使用 Linux 命令清空大文件

3. 使用 cat/cp/dd 實用工具及 /dev/null 設備來清空文件

在 Linux 中, null 設備基本上被用來丟棄某個進程不再需要的輸出流,或者作為某個輸入流的空白文件,這些通常可以利用重定向機制來達到。

所以 /dev/null 設備文件是一個特殊的文件,它將清空送到它這裡來的所有輸入,而它的輸出則可被視為一個空文件。

另外,你可以通過使用 cat 命令 顯示 /dev/null 的內容然後重定向輸出到某個文件,以此來達到清空該文件的目的。

# cat /dev/null > access.log

Empty File Using cat Command

使用 cat 命令來清空文件

下面,我們將使用 cp 命令 複製 /dev/null 的內容到某個文件來達到清空該文件的目的,具體如下所示:

# cp /dev/null access.log

Empty File Content Using cp Command

使用 cp 命令來清空文件

而下面的命令中, if 代表輸入文件,of 代表輸出文件。

# dd if=/dev/null of=access.log

Empty File Content Using dd Command

使用 dd 命令來清空文件內容

4. 使用 echo 命令清空文件

在這裡,你可以使用 echo 命令 將空字元串的內容重定向到文件中,具體如下:

# echo "" > access.log
或者
# echo > access.log

Empty File Using echo Command

使用 echo 命令來清空文件

注意:你應該記住空字元串並不等同於 null 。字元串表明它是一個具體的事物,只不過它的內容可能是空的,但 null 則意味著某個事物並不存在。

基於這個原因,當你將 echo 命令 的輸出作為輸入重定向到文件後,使用 cat 命令 來查看該文件的內容時,你將看到一個空白行(即一個空字元串)。

要將 null 做為輸出輸入到文件中,你應該使用 -n 選項,這個選項將告訴 echo 不再像上面的那個命令那樣輸出結尾的那個新行。

# echo -n "" > access.log

Empty File Using Null Redirect

使用 Null 重定向來清空文件

5. 使用 truncate 命令來清空文件內容

truncate 可被用來將一個文件縮小或者擴展到某個給定的大小

你可以利用它和 -s 參數來特別指定文件的大小。要清空文件的內容,則在下面的命令中將文件的大小設定為 0:

# truncate -s 0 access.log

Truncate File Content in Linux

在 Linux 中截斷文件內容

我要介紹的就是這麼多了。在本文中,我們介紹了幾種通過使用一些簡單的命令行工具和 shell 重定向機制來清除或清空文件內容的方法。

上面介紹的這些可能並不是達到清空文件內容這個目的的所有可行的實踐方法,所以你也可以通過下面的評論欄告訴我們本文中尚未提及的其他方法。

via: http://www.tecmint.com/empty-delete-file-content-linux/

作者:Aaron Kili 譯者:FSSlc 校對:jasminepeng

本文由 LCTT 原創編譯,Linux中國 榮譽推出


本文轉載來自 Linux 中國: https://github.com/Linux-CN/archive

對這篇文章感覺如何?

太棒了
0
不錯
0
愛死了
0
不太好
0
感覺很糟
0
雨落清風。心向陽

    You may also like

    Leave a reply

    您的郵箱地址不會被公開。 必填項已用 * 標註

    這個站點使用 Akismet 來減少垃圾評論。了解你的評論數據如何被處理

    More in:Linux中國

    Linux中國

    關於Linux防火牆iptables的面試問答

    Nishita Agarwal是Tecmint的用戶,她將分享關於她剛剛經歷的一家公司(印度的一家私人公司Pune)的面試經驗。在面試中她被問及許多不同的問題,但她是iptables方面的專家,因此她想分享這些關於iptables的問題和相應的答案給那些以後可能會進行相關面試的人。 所有的問題和相應的答案都基於Nishita Agarwal的記憶並經過了重寫。 嗨,朋友!我叫Nishita Agarwal。我已經取得了理學學士學位,我的專業集中在UNIX和它的變種(BSD,Linux)。它們一直深深的吸引著我。我在存儲方面有1年多的經驗。我正在尋求職業上的變化,並將供職於印度的P
    Linux中國

    Lets Encrypt 已被所有主流瀏覽器所信任

    旨在讓每個網站都能使用 HTTPS 加密的非贏利組織 Lets Encrypt 已經得了 IdenTrust的交叉簽名,這意味著其證書現在已經可以被所有主流的瀏覽器所信任。從這個裡程碑事件開始,訪問者訪問使用了Lets Encrypt 證書的網站不再需要特別配置就可以得到 HTTPS 安全保護了。 Lets Encrypt 的兩個中級證書 ...
    Linux中國

    SSL/TLS 加密新紀元 – Lets Encrypt

    根據 Let's Encrypt 官方博客消息,Let's Encrypt 服務將在下周(11 月 16 日)正式對外開放。 Let's Encrypt 項目是由互聯網安全研究小組(ISRG,Internet Security Research Group)主導並開發的一個新型數字證書認證機構(CA,Certificate ...