本文介紹了tar命令、gzip, zcat 命令、bzip2, bzcat 命令、compress 命令、dd 命令、cpio 命令,具體如下:
tar命令
解壓文件到指定目錄:
tar -zxvf /home/zjx/aa.tar.gz -C /home/zjx/pf
tar [-cxtzjvfpPN] 文件與目錄....
參數:
-c :建立一個壓縮文件的參數指令(create 的意思);
-x :解開一個壓縮文件的參數指令!
-t :查看tarfile 里面的文件!
特別注意,在參數的下達中,c/x/t 僅能存在一個!不可同時存在!
因為不可能同時壓縮與解壓縮。
-z :是否同時具有gzip 的屬性?亦即是否需要用gzip 壓縮?
-j :是否同時具有bzip2 的屬性?亦即是否需要用bzip2 壓縮?
-v :壓縮的過程中顯示文件!這個常用,但不建議用在背景執行過程!
-f :使用檔名,請留意,在f 之后要立即接檔名喔!不要再加參數!
例如使用『tar -zcvfP tfile sfile』就是錯誤的寫法,要寫成
『tar -zcvPf tfile sfile』才對喔!
-p :使用原文件的原來屬性(屬性不會依據使用者而變)
-P :可以使用絕對路徑來壓縮!
-N :比后面接的日期(yyyy/mm/dd)還要新的才會被打包進新建的文件中!
--exclude FILE:在壓縮的過程中,不要將FILE 打包!
范例:
范例一:將整個/etc 目錄下的文件全部打包成為/tmp/etc.tar
[root@linux ~]# tar -cvf /tmp/etc.tar /etc <==僅打包,不壓縮![root@linux ~]# tar -zcvf /tmp/etc.tar.gz /etc <==打包后,以gzip 壓縮[root@linux ~]# tar -jcvf /tmp/etc.tar.bz2 /etc <==打包后,以bzip2 壓縮# 特別注意,在參數f 之后的文件檔名是自己取的,我們習慣上都用.tar 來作為辨識。# 如果加z 參數,則以.tar.gz 或.tgz 來代表gzip 壓縮過的tar file ~# 如果加j 參數,則以.tar.bz2 來作為附檔名啊~# 上述指令在執行的時候,會顯示一個警告訊息:# 『tar: Removing leading `/' from member names』那是關於絕對路徑的特殊設定。
范例二:查閱上述/tmp/etc.tar.gz 文件內有哪些文件?
[root@linux ~]# tar -ztvf /tmp/etc.tar.gz# 由於我們使用gzip 壓縮,所以要查閱該tar file 內的文件時,# 就得要加上z 這個參數了!這很重要的!
范例三:將/tmp/etc.tar.gz 文件解壓縮在/usr/local/src 底下
[root@linux ~]# cd /usr/local/src[root@linux src]# tar -zxvf /tmp/etc.tar.gz# 在預設的情況下,我們可以將壓縮檔在任何地方解開的!以這個范例來說,# 我先將工作目錄變換到/usr/local/src 底下,并且解開/tmp/etc.tar.gz ,# 則解開的目錄會在/usr/local/src/etc 呢!另外,如果您進入/usr/local/src/etc# 則會發現,該目錄下的文件屬性與/etc/ 可能會有所不同喔!
范例四:在/tmp 底下,我只想要將/tmp/etc.tar.gz 內的etc/passwd 解開而已
[root@linux ~]# cd /tmp[root@linux tmp]# tar -zxvf /tmp/etc.tar.gz etc/passwd# 我可以透過tar -ztvf 來查閱tarfile 內的文件名稱,如果單只要一個文件,# 就可以透過這個方式來下達!注意到!etc.tar.gz 內的根目錄/ 是被拿掉了!
范例五:將/etc/ 內的所有文件備份下來,并且保存其權限!
[root@linux ~]# tar -zxvpf /tmp/etc.tar.gz /etc# 這個-p 的屬性是很重要的,尤其是當您要保留原本文件的屬性時!
范例六:在/home 當中,比2005/06/01 新的文件才備份
[root@linux ~]# tar -N '2005/06/01' -zcvf home.tar.gz /home
范例七:我要備份/home, /etc ,但不要/home/dmtsai
[root@linux ~]# tar --exclude /home/dmtsai -zcvf myfile.tar.gz /home/* /etc
范例八:將/etc/ 打包后直接解開在/tmp 底下,而不產生文件!
[root@linux ~]# cd /tmp[root@linux tmp]# tar -cvf - /etc | tar -xvf -# 這個動作有點像是cp -r /etc /tmp 啦~依舊是有其有用途的!# 要注意的地方在於輸出檔變成- 而輸入檔也變成- ,又有一個| 存在~# 這分別代表standard output, standard input 與管線命令啦!# 這部分我們會在Bash shell 時,再次提到這個指令跟大家再解釋啰!
gzip, zcat 命令
[root@linux ~]# gzip [-cdt#] 檔名[root@linux ~]# zcat 檔名.gz
參數:
-c :將壓縮的資料輸出到螢幕上,可透過資料流重導向來處理;
-d :解壓縮的參數;
-t :可以用來檢驗一個壓縮檔的一致性~看看文件有無錯誤;
-# :壓縮等級,-1 最快,但是壓縮比最差、-9 最慢,但是壓縮比最好!預設是-6 ~
范例:
范例一:將/etc/man.config 複制到/tmp ,并且以gzip 壓縮
[root@linux ~]# cd /tmp[root@linux tmp]# cp /etc/man.config .[root@linux tmp]# gzip man.config# 此時man.config 會變成man.config.gz !
范例二:將范例一的文件內容讀出來!
[root@linux tmp]# zcat man.config.gz# 此時螢幕上會顯示man.config.gz 解壓縮之后的文件內容??!
范例三:將范例一的文件解壓縮
[root@linux tmp]# gzip -d man.config.gz
范例四:將范例三解開的man.config 用最佳的壓縮比壓縮,并保留原本的文件
[root@linux tmp]# gzip -9 -c man.config > man.config.gz
bzip2, bzcat 命令
[root@linux ~]# bzip2 [-cdz] 檔名[root@linux ~]# bzcat 檔名.bz2
參數:
-c :將壓縮的過程產生的資料輸出到螢幕上!
-d :解壓縮的參數
-z :壓縮的參數
-# :與gzip 同樣的,都是在計算壓縮比的參數,-9 最佳,-1 最快!
范例:
范例一:將剛剛的/tmp/man.config 以bzip2 壓縮
[root@linux tmp]# bzip2 -z man.config# 此時man.config 會變成man.config.bz2 !
范例二:將范例一的文件內容讀出來!
[root@linux tmp]# bzcat man.config.bz2# 此時螢幕上會顯示man.config.bz2 解壓縮之后的文件內容??!
范例三:將范例一的文件解壓縮
[root@linux tmp]# bzip2 -d man.config.bz2
范例四:將范例三解開的man.config 用最佳的壓縮比壓縮,并保留原本的文件
[root@linux tmp]# bzip2 -9 -c man.config > man.config.bz2
compress 命令
[root@linux ~]# compress [-dcr] 文件或目錄
參數:
-d :用來解壓縮的參數
-r :可以連同目錄下的文件也同時給予壓縮呢!
-c :將壓縮資料輸出成為standard output (輸出到螢幕)
范例:
范例一:將/etc/man.config 複制到/tmp ,并加以壓縮
[root@linux ~]# cd /tmp[root@linux tmp]# cp /etc/man.config .[root@linux tmp]# compress man.config[root@linux tmp]# ls -l-rw-r--r-- 1 root root 2605 Jul 27 11:43 man.config.Z
范例二:將剛剛的壓縮檔解開
[root@linux tmp]# compress -d man.config.Z
范例三:將man.config 壓縮成另外一個文件來備份
[root@linux tmp]# compress -c man.config > man.config.back.Z[root@linux tmp]# ll man.config*-rw-r--r-- 1 root root 4506 Jul 27 11:43 man.config-rw-r--r-- 1 root root 2605 Jul 27 11:46 man.config.back.Z# 這個-c 的參數比較有趣!他會將壓縮過程的資料輸出到螢幕上,而不是寫入成為# file.Z 文件。所以,我們可以透過資料流重導向的方法將資料輸出成為另一個檔名。# 關於資料流重導向,我們會在bash shell 當中詳細談論的啦!
dd 命令
[root@linux ~]# dd if="input_file" of="outptu_file" bs="block_size" /count="number"
參數:
if :就是input file 啰~也可以是裝置喔!
of :就是output file 喔~也可以是裝置;
bs :規劃的一個block 的大小,如果沒有設定時,預設是512 bytes
count:多少個bs 的意思。
范例:
范例一:將/etc/passwd 備份到/tmp/passwd.back 當中
[root@linux ~]# dd if=/etc/passwd of=/tmp/passwd.back3+1 records in3+1 records out[root@linux ~]# ll /etc/passwd /tmp/passwd.back-rw-r--r-- 1 root root 1746 Aug 25 14:16 /etc/passwd-rw-r--r-- 1 root root 1746 Aug 29 16:57 /tmp/passwd.back# 仔細的看一下,我的/etc/passwd 文件大小為1746 bytes,因為我沒有設定bs ,# 所以預設是512 bytes 為一個單位,因此,上面那個3+1 表示有3 個完整的# 512 bytes,以及未滿512 bytes 的另一個block 的意思啦!# 事實上,感覺好像是cp 這個指令啦~
范例二:備份/dev/hda 的MBR
[root@linux ~]# dd if=/dev/hda of=/tmp/mbr.back bs=512 count=11+0 records in1+0 records out# 這就得好好瞭解一下啰~我們知道整顆硬盤的MBR 為512 bytes,# 就是放在硬盤的第一個sector 啦,因此,我可以利用這個方式來將# MBR 內的所有資料都紀錄下來,真的很厲害吧!
范例三:將整個/dev/hda1 partition 備份下來。
[root@linux ~]# dd if=/dev/hda1 of=/some/path/filenaem# 這個指令很厲害啊!將整個partition 的內容全部備份下來~# 后面接的of 必須要不是在/dev/hda1 的目錄內啊~否則,怎么讀也讀不完~# 這個動作是很有效用的,如果改天你必須要完整的將整個partition 的內容填回去,# 則可以利用dd if=/some/file of=/dev/hda1 來將資料寫入到硬盤當中。# 如果想要整個硬盤備份的話,就類似Norton 的ghost 軟體一般,# 由disk 到disk ,嘿嘿~利用dd 就可以啦~厲害厲害!
cpio 命令
[root@linux ~]# cpio -covB > [file|device] <==備份[root@linux ~]# cpio -icduv < [file|device] <==還原
參數:
-o :將資料copy 輸出到文件或裝置上
-i :將資料自文件或裝置copy 出來系統當中
-t :查看cpio 建立的文件或裝置的內容
-c :一種較新的portable format 方式儲存
-v :讓儲存的過程中文件名稱可以在螢幕上顯示
-B :讓預設的Blocks 可以增加至5120 bytes ,預設是512 bytes !
這樣的好處是可以讓大文件的儲存速度加快(請參考i-nodes 的觀念)
-d :自動建立目錄!由於cpio 的內容可能不是在同一個目錄內,
如此的話在反備份的過程會有問題! 這個時候加上-d 的話,
就可以自動的將需要的目錄建立起來了!
-u :自動的將較新的文件覆蓋較舊的文件!
范例:
范例一:將所有系統上的資料通通寫入磁帶機內!
[root@linux ~]# find / -print | cpio -covB > /dev/st0# 一般來說,使用SCSI 介面的磁帶機,代號是/dev/st0 喔!
范例二:檢查磁帶機上面有什么文件?
[root@linux ~]# cpio -icdvt < /dev/st0[root@linux ~]# cpio -icdvt < /dev/st0 > /tmp/content# 第一個動作當中,會將磁帶機內的檔名列出到螢幕上面,而我們可以透過第二個動作,# 將所有的檔名通通紀錄到/tmp/content 文件去!
范例三:將磁帶上的資料還原回來~
[root@linux ~]# cpio -icduv < /dev/st0# 一般來說,使用SCSI 介面的磁帶機,代號是/dev/st0 喔!
范例四:將/etc 底下的所有『文件』都備份到/root/etc.cpio 中!
[root@linux ~]# find /etc -type f | cpio -o > /root/etc.cpio# 這樣就能夠備份啰~您也可以將資料以cpio -i < /root/etc.cpio# 來將資料捉出來?。。?!
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。
新聞熱點
疑難解答
圖片精選