最近總是用到這個指令,正好轉一篇吧
==========================================================================
tar指令
[root@linux ~]# 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 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 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
[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 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.back
3+1 records in
3+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=1
1+0 records in
1+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
# 來将資料捉出來!!!!