[code] tar命令 【這個只是打包哦 不是壓縮】下面的才是壓縮哦 解包:tar zxvf FileName.tar 打包:tar czvf FileName.tar DirName gz命令 解壓1:gunzip FileName.gz 解壓2:gzip -d FileName.gz 壓縮:gzip FileName .tar.gz 和 .tgz 解壓:tar zxvf FileName.tar.gz 壓縮:tar zcvf FileName.tar.gz DirName 壓縮多個文件:tar zcvf FileName.tar.gz DirName1 DirName2 DirName3 ... bz2命令 解壓1:bzip2 -d FileName.bz2 解壓2:bunzip2 FileName.bz2 壓縮: bzip2 -z FileName .tar.bz2 解壓:tar jxvf FileName.tar.bz2 壓縮:tar jcvf FileName.tar.bz2 DirName bz命令 解壓1:bzip2 -d FileName.bz 解壓2:bunzip2 FileName.bz 壓縮:未知 .tar.bz 解壓:tar jxvf FileName.tar.bz Z命令 解壓:uncompress FileName.Z 壓縮:compress FileName .tar.Z 解壓:tar Zxvf FileName.tar.Z 壓縮:tar Zcvf FileName.tar.Z DirName zip命令 解壓:unzip FileName.zip 壓縮:zip FileName.zip DirName 上面這個多看看 主要是tar 其他的知道就可以哦 下面是例子 有時間了看看 tar 用的最多 參數介紹如下: -z :是否同時具有 gzip 的屬性?亦即是否需要用 gzip 壓縮? -x :解開一個壓縮文件的參數指令! -v :壓縮的過程中顯示文件!這個常用 -f :使用檔名,請留意,在 f 之後要立即接檔名喔!不要再加參數! -p :使用原文件的原來屬性(屬性不會依據使用者而變) -P :可以使用絕對路徑來壓縮! -N :比後面接的日期(yyyy/mm/dd)還要新的才會被打包進新建的文件中! 例子: 壓縮文件 [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 與管線命令啦! 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.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 # 來將資料捉出來!!!!