<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-314  評論-209  文章-0  trackbacks-0
    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 ~]# 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.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
    # 來將資料捉出來!!!!
    posted on 2010-07-12 16:47 xzc 閱讀(239) 評論(0)  編輯  收藏 所屬分類: linux/unix
    主站蜘蛛池模板: a一级爱做片免费| 无码 免费 国产在线观看91| 成人无码WWW免费视频| 亚洲精品成人在线| sss日本免费完整版在线观看| 在线观看亚洲免费| 美女18一级毛片免费看| 亚洲Av无码国产情品久久| 51午夜精品免费视频| 亚洲精品午夜无码电影网| 两性色午夜免费视频| 亚洲AV永久无码精品成人| 6080午夜一级毛片免费看6080夜福利| 亚洲成a人片在线观看中文动漫| 99精品视频在线观看免费播放| 亚洲天天在线日亚洲洲精| 无人在线直播免费观看| 亚洲欧美国产国产综合一区| 免费v片视频在线观看视频| 无遮挡呻吟娇喘视频免费播放 | 最新欧洲大片免费在线| 亚洲va乱码一区二区三区| 色吊丝最新永久免费观看网站 | 亚洲av纯肉无码精品动漫| 亚洲AV成人精品日韩一区18p| av成人免费电影| 亚洲精品电影在线| 国产精品视频免费一区二区三区| 色多多A级毛片免费看| 国产亚洲精品xxx| 最新中文字幕免费视频| 免费一级毛片在线播放放视频| 亚洲国产精品高清久久久| 99久久免费精品国产72精品九九| 麻豆91免费视频| 亚洲第一福利网站| 国产一区二区三区在线免费| 日本免费电影一区二区| 亚洲精品无码久久久久APP| 亚洲精品中文字幕乱码三区| 成年女人免费视频播放77777|