tar

可以將多個檔案組合成一個名為「tarball」的單個檔案的電腦檔案格式

tarUnix類Unix系統上的歸檔打包工具,可以將多個文件合併為一個文件,打包後的文件名亦為「tar」。目前,tar文件格式已經成為POSIX標準,最初是POSIX.1-1988,目前是POSIX.1-2001。本程序最初的設計目的是將文件備份到磁帶上(tape archive),因而得名tar。

tar
GNU tar 1.16版顯示出三種常用的Tarball(圖中紅字)
副檔名
.tar
網路媒體型式
application/x-tar
統一類型標識public.tar-archive
格式類型文件歸檔器
使用容器gzip, bzip2, LZMA, xz, lzop, compress
免費格式?
Tar
開發者GNU計劃
操作系統跨平臺
類型文件歸檔器
許可協議GNU通用公共許可證
網站https://www.gnu.org/software/tar/

版本

常用的tar是自由軟件基金會開發的GNU版,目前的穩定版本是1.33,發布於2021年1月7日 (2021-01-07)

縮寫

 
Tar經常和別的壓縮方式一起使用,比如gzip,來生成壓縮文檔。如圖所示,結合檔案中的文件被壓縮為一個單位。

tar代表未壓縮的tar文件。已壓縮的tar文件則附加數據壓縮格式的擴展名,如經過gzip壓縮後的tar文件,擴展名為「.tar.gz」。由於受到DOS8.3文件名格式的限制,常使用下列縮寫:

  • .tgz等價於.tar.gz
  • .tbz與tb2等價於.tar.bz2
  • .taz等價於.tar.Z
  • .tlz等價於.tar.lzma
  • .txz等價於.tar.xz

GNU tar的用法

命令格式是

tar 功能 選項 檔案

可以將代表功能和選項的單個字母合併;當使用單個字母時,可以不用在字母前面加「-」。某些版本的tar要求嚴格按照功能字、選項字的順序,而有些版本的tar並不在意這個順序。

功能

  • -c,--create 建立新的tar檔案
  • -x,--extract,--get 解開tar文件
  • -t,--list 列出tar文件中包含的文件的信息
  • -r,--append 附加新的文件到tar文件中
  • -u,--update 用已打包的文件的較新版本更新tar文件
  • -A,--catenate,--concatenate 將tar文件作為一個整體追加到另一個tar文件中
  • -d,--diff,--compare 將文件系統裡的文件和tar文件里的文件進行比較
  • --delete 刪除tar文件里的文件。注意,這個功能不能用於已保存在磁帶上的tar文件!

常用選項

  • -v,--verbose 列出每一步處理涉及的文件的信息,只用一個「v」時,僅列出文件名,使用兩個「v」時,列出權限、所有者、大小、時間、文件名等信息。
  • -k,--keep-old-files 不覆蓋文件系統上已有的文件
  • -f,--file [主機名:]文件名 指定要處理的文件名。可以用「-」代表標準輸出標準輸入
  • -P,--absolute-names 使用絕對路徑
  • -j,--bzip2 調用bzip2執行壓縮或解壓縮。注意,由於部分老版本的tar使用-I實現本功能,因此,編寫腳本時,最好使用--bzip2。
  • -J,--xz,--lzma 調用XZ Utils英語XZ Utils執行壓縮或解壓縮。依賴XZ Utils。
  • -z,--gzip,--gunzip,--ungzip 調用gzip執行壓縮或解壓縮
  • -Z,--compress,--uncompress 調用compress執行壓縮或解壓縮

應用示例

 tar -cvf home_backup.tar /home

可以將/home目錄下的所有文件打包入home_backup.tar文件中。理解這個命令時,請注意「home_backup.tar」實際上是-f選項的參數。tar默認記錄相對路徑,即使給出的是絕對路徑,也會自動將代表根目錄的「/」去掉,所以,在這個例子中,使用「/home」和「home」是相同的。要想使用絕對路徑,請加上「P」選項,但一般不推薦使用絕對路徑,原因之一是可能導致tar炸彈攻擊。

 cd /home
 tar -cvf home_backup.tar *

這也是一種製作備份的方法,但是不推薦這樣做。因為tar在默認解壓時,會將文件直接輸出到當前目錄下,而不會新建並輸出到一個名為home的子目錄,令到當前目錄顯得很凌亂。這也是一種形式的tar炸彈攻擊。

 tar -tf home_backup.tar

列出home_backup.tar文件里已被打包的文件。此時僅僅顯示文件名。如果加上「v」,則能列出權限、所有者、大小、時間、文件名等信息。為防止tar炸彈攻擊,應該養成解壓前查看tar文件內容的好習慣。

 tar -xvf home_backup.tar

在當前目錄下解壓home_back.tar。解壓後的文件,其訪問權限得到保留;其所有者是執行tar命令的用戶,如果tar的執行者是root,則所有者是文件原來的所有者。 解壓前,最好先查看tar文件的內容,以決定是否需要新建一個臨時子目錄安放。

 tar -xvf home_backup.tar home/test.c

指定解壓出test.c這個文件。解壓過程中會自動創建home這個子目錄。

其他

替代

由於備份策略的進步,逐漸採用dumprestore等工具替代tar。此後,tar多與gzip聯用,彌補後者無法將多個文件打包的不足。這一用法沿用至今,新的tar版本已能自動調用多種壓縮工具執行壓縮。已壓縮的tar文件也叫「tarball」。大部分自由軟件的源代碼採用tarball的形式發布。

tar炸彈

攻擊者利用絕對路徑,或者「tar -cf bomb.tar *」的方式創建的tar文件,然後誘騙受害者在根目錄下解壓,或者使用絕對路徑解壓。可能使受害系統上已有的文件被覆蓋掉,或者導致當前工作目錄凌亂不堪,這就是所謂的「tar炸彈」。因此,要養成良好的解壓習慣:

  • 解壓前用「t」查看tar的文件內容。
  • 拒絕使用絕對路徑。
  • 新建一個臨時子目錄,然後在這個子目錄里解壓。

tar管道

管道用法:

 tar -c "${源目录}" | tar -xvC "${目标目录}"

文件默認是標準輸入/輸出,不需再額外指定。可以將源目錄下的文件及子目錄複製到目標目錄中,尤其適用於複製含有特殊文件(如軟鏈接設備文件)的目錄。

另見

  • JAR:製作的指令相似,但使用的是 ZIP 壓縮。