linux系统常见的压缩指令
一般被压缩过的档案,通常其附档名都是【*.tar,*.tar.gz,*.tgz,*.gz,*.Z,*.bz2】等等。
*.tar:tar程序打包的数据。并没有压缩过
*.tar.gz:tar程序打包的档案,其中并且经过gzip的压缩
*.gz:gzip程序压缩的档案
*.Z:compress程序压缩的档案
*.bz2:bzip2程序压缩的档案
compress
[root@linux ~]# compress [-dcr] 档案或目录 参数: -d :用来解压缩的参数 -r :可以连同目录下的档案也同时给予压缩呢! -c :将压缩数据输出成为 standard output (输出到屏幕)
解压缩除了可以compress -d这个参数之外,还可以直接使用 uncompress。
gzip,zcat
[root@linux ~]# gzip [-cdt#] 檔名 [root@linux ~]# zcat 檔名.gz 参数: -c :将压缩的数据输出到屏幕上,可透过数据流重导向来处理; -d :解压缩的参数; -t :可以用来检验一个压缩档的一致性~看看档案有无错误; -# :压缩等级,- 最快,但是压缩比最差、- 最慢,但是压缩比最好!预设是 -
由于gzip这个压缩指令主要想要用来取代compress的,所有compress的压缩档案也可以使用gzip来解开。同时,zcat这个指令可以同时读取compress和gzip的压缩档。
bzip2,bzcat
[root@linux ~]# bzip2 [-cdz] 檔名 [root@linux ~]# bzcat 檔名.bz2 参数: -c :将压缩的过程产生的数据输出到屏幕上! -d :解压缩的参数 -z :压缩的参数 -# :与 最佳, - 最快!
同样的,也可以使用bunzip2这个指令来取代bzip2 -d。
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 打包
dd
这个指令不只是能制作一个档案而已,dd指令最大的功效应该在于【备份】。因为dd可以读取装置的内容,然后将这个装置备份成一个档案。
[root@linux ~]# dd if="input_file" of="outptu_file" bs="block_size" \ count="number" 参数: if :就是 input file 也可以是装置 of :就是 output file 也可以是装置; bs:规划的一个 block 的大小,如果没有设定时,预设是 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 可以增加至 bytes ,预设是 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# 来将资料捉出来
这个 cpio 是备份的时候的一项利器,因为他可以备份任何的档案, 包括 /dev 底下的任何装置档案!而由于 cpio 必需要配合其它的程序,例如 find 来建立档名,所以, cpio 与管线命令及数据流重导向的相关性就相当的重要了!