linux学习第十九篇:压缩介绍,gzip,bzip2,xz压缩工具

  • file命令可查看文件是压缩文件或者test文件等,如file 1.txt 可查看1.txt是什么类型的文件

linux压缩打包介绍

在windows下我们接触最多的压缩文件就是.rar格式的了。但在linux下这样的格式是不能识别的,它有自己所特有的压缩工具。但有一种文件在windows和linux下都能使用那就是.zip格式的文件了。它不仅能节省磁盘空间而且在传输的时候还能节省网络带宽。 在linux下最常见的压缩文件通常都是以.tar.gz 为结尾的,除此之外还有.tar, .gz, .bz2, .zip, .tar.xz, .tar.bz2等等。以前也介绍过linux系统中的后缀名其实要不要无所谓,但是对于压缩文件来讲必须要带上。这是为了判断压缩文件是由哪种压缩工具所压缩,而后才能去正确的解压缩这个文件。以下介绍常见的后缀名所对应的压缩工具。

.gz gzip 压缩工具压缩的文件

.bz2 bzip2 压缩工具压缩的文件

.tar tar 打包程序打包的文件(tar并没有压缩功能,只是把一个目录合并成一个文件)

.tar.gz 可以理解为先用tar打包,然后再gzip压缩

.tar.bz2 同上,先用tar打包,然后再bzip2压缩

.

gzip压缩工具

语法命令: gzip 1.txt //压缩文件1.txt。gzip 是不支持压缩目录的。

gzip -d 1.txt.gz //-d 解压压缩包1.txt.gz gunzip 1.txt.gz //解压压缩包1.txt.gz

gzip -# 1.txt //# 为压缩等级,1压缩最差,9压缩最好,6为默认,压缩得越好耗费的CPU资源越大。平时很少用,使用默认压缩级别足够了。

file 1.txt.gz //查看压缩文件里有什么文件

zcat 1.txt.gz //查看压缩文件里的内容,先解压再cat查看

gzip -c 1.txt > /tmp/1.txt.gz //生成一个压缩文件1.txt.gz在/tmp目录下,源文件1.txt还是存在。

gzip -d -c /tmp/1.txt.gz > /tmp/2.txt //源压缩文件1.txt.gz不变,再解压缩1.txt到/tmp下并改名2.txt

[root@xie-02 zzz]# du -sh 1.txt   
2.3M    1.txt
[root@xie-02 zzz]# wc -l 1.txt 
35735 1.txt
[root@xie-02 zzz]# gzip 1.txt   //压缩文件
[root@xie-02 zzz]# ls
1.txt.gz
[root@xie-02 zzz]# du -sh 1.txt.gz //压缩后的文件大小
360K    1.txt.gz
[root@xie-02 zzz]# gzip -d 1.txt.gz //解压文件
[root@xie-02 zzz]# 
[root@xie-02 zzz]# du -sh 1.txt     //由原本的2.3M解压后变成1.4M是因为原本的2.3M是虚的,没有那么大,压缩后把虚的那些空间挤掉,所以实际上的大小为1.4M
1.4M    1.txt
[root@xie-02 zzz]# wc -l 1.txt   //大小跟原来没压缩前一样是35735行没有变化,更能证明之前的2.3M是虚的,实际是1.4M
35735 1.txt
[root@xie-02 zzz]# gzip -1 1.txt //最差的压缩等级1
[root@xie-02 zzz]# du -sh 1.txt.gz 
424K    1.txt.gz
[root@xie-02 zzz]# gzip -d 1.txt.gz 
[root@xie-02 zzz]# gzip -9 1.txt //最好的压缩等级9
[root@xie-02 zzz]# du -sh 1.txt.gz 
356K    1.txt.gz

bzip2压缩工具

bzip2比gzip压缩得更狠,但也意味着耗费的cpu资源也越多。

bzip2 1.txt //压缩文件1.txt。bzip2 是不支持压缩目录的。 bzip2 -z 1.txt //压缩文件1.txt,同上

bzip2 -d 1.txt.bz2 //-d 解压压缩包1.txt.bz2 bunzip2 1.txt.bz2 //解压压缩包1.txt.bz2

bzip -# 1.txt //#范围1-9,默认9

file 1.txt.bz2 //查看压缩文件里有什么文件

bzcat 1.txt.bz2 //查看压缩文件里的内容,先解压再cat查看

bzip2 -c 1.txt > /tmp/1.txt.bz2 //生成一个压缩文件1.txt.bz2在/tmp目录下,源文件1.txt还是存在。

bzip2 -c -d /tmp/1.txt.bz2 > /tmp/2.txt //源压缩文件1.txt.bz2不变,再解压缩1.txt到/tmp下并改名2.txt

[root@xie-02 zzz]# du -sh 1.txt 2.txt 
1.4M    1.txt
1.4M    2.txt
[root@xie-02 zzz]# gzip 1.txt 
[root@xie-02 zzz]# bzip2 2.txt 
[root@xie-02 zzz]# ls
1.txt.gz  2.txt.bz2
[root@xie-02 zzz]# du -sh 1.txt.gz 2.txt.bz2   //bzip2压缩程度比gzip更强
360K    1.txt.gz
172K    2.txt.bz2

xz压缩工具

bzip2比gzip压缩得更狠,而xz比bzip2压缩得更狠。但也意味着耗费的cpu资源也越多。 所以压缩q强度上xz>bzip>gzip,但不是绝对的,有些文件可能适合其中一种。

xz 1.txt // 压缩文件1.txt。xz 是不支持压缩目录的。 xz -z 1.txt //压缩文件1.txt,同上

xz -d 1.txt.xz // -d 解压压缩包1.txt.xz unxz 1.txt.xz //解压压缩包1.txt.xz

xz -# 1.txt //#范围1-9,默认6

file 1.txt.xz //查看压缩文件里有什么文件

xzcat 1.txt.xz //查看压缩文件里的内容,先解压再cat查看

xz -c 1.txt > /tmp/1.txt.xz //生成一个压缩文件1.txt.xz在/tmp目录下,源文件1.txt还是存在。

xz -d -c /tmp/1.txt.xz > 2.txt //源压缩文件1.txt.xz不变,再解压缩1.txt到/tmp下并改名2.txt

[root@xie-02 zzz]# du -sh 1.txt 2.txt 
1.4M    1.txt
1.4M    2.txt
[root@xie-02 zzz]# bzip2 1.txt 
[root@xie-02 zzz]# xz 2.txt 
[root@xie-02 zzz]# ls
1.txt.bz2  2.txt.xz
[root@xie-02 zzz]# du -sh 1.txt.bz2 2.txt.xz 
172K    1.txt.bz2
64K     2.txt.xz

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏码神联盟

框架 | SpringBoot项目发布到自动化容器Docker步骤

4943
来自专栏数据和云

YH12:一篇文章读懂SCAN

单客户端访问名称(SCAN)是Oracle RAC环境中使用的功能,为客户端提供访问集群中运行的任何Oracle数据库的单一名称。 用户可以将SCAN视为RAC...

3566
来自专栏实战docker

Docker下dubbo开发,三部曲之二:本地环境搭建

在上一篇文章《Docker下dubbo开发,三部曲之一:极速体验》中,我们快速体验了dubbo服务的注册、发现、调用,今天我们一起在本地制作一套这样的环境,经过...

3447
来自专栏IT民工生存指南

初试 Kubernetes -集群搭建

主节点(个人很喜欢腾讯云的主机自动命名,内网IP之类的都已经在hostname里了,不容易出错)

2474
来自专栏运维前线

CentOS6 安装couchdb2 集群

CentOS6 安装couchdb2 集群 参考:http://blog.csdn.net/wh211212/article/details/74359497...

24610
来自专栏JMCui

Docker 系列五(Docker Compose 项目).

    Docker Compose 是官方编排项目之一,负责快速的部署分布式应用。它允许用户通过一个单独的 docker-compose.yml 模板文件(Y...

942

Docker in Action:共享内存命名空间

本文摘自“ Docker in Action ”(Docker实战)一书,将向您展示在容器之间共享内存的方法。

5327
来自专栏腾讯云TStack专栏

qemu-kvm中vcpu虚拟化到底是咋整的?

一句话总结 实例化一个vcpu就是在hostOS中创建了一个线程,线程里有个while循环,循环里不停的调用kvm_cpu_exec方法,kvm_cpu_e...

71310
来自专栏恰童鞋骚年

Java微服务之Spring Boot on Docker

本文学习前提:Java, Spring Boot, Docker, Spring Cloud

2624
来自专栏小狼的世界

Kubernetes中Pod的健康检查

我们先来看一下Kubernetes的架构图,每个Node节点上都有 kubelet ,Container Probe 也就是容器的健康检查是由 kubelet ...

2781

扫码关注云+社区

领取腾讯云代金券