一、压缩和解压介绍

Linux下最常用的打包命令就是tar,使用tar命令打包后,就可以用其它的命令来进行压缩了。tar命令的使用方法
tar命令
[root@dingjian ~]# tar [-cxtzjvfpPN] 文件与目录 ....
参数:
-c :建立一个压缩文件的参数指令(create 的意思);
-x :解开一个压缩文件的参数指令!
-t :查看 tarfile 里面的文件!
特别注意,在参数的下达中, c/x/t 仅能存在一个!不可同时存在!
因为不可能同时压缩与解压缩。
-z :是否同时具有 gzip 的属性?亦即是否需要用 gzip 压缩?
-j :是否同时具有 bzip2 的属性?亦即是否需要用 bzip2 压缩?
-v :压缩的过程中显示文件!这个常用,但不建议用在背景执行过程!
-f :使用档名,请留意,在 f 之后要立即接档名喔!不要再加参数!
-C(大写) : 目录 这个参数用在解压缩时,若要在特定目录解压缩,可以使用这个参数
-p :使用原文件的原来属性(属性不会依据使用者而变)
-P (大写):可以使用绝对路径来压缩!.
-N :比后面接的日期(yyyy/mm/dd)还要新的才会被打包进新建的文件中!
--exclude FILE:在压缩的过程中,不要将 FILE 打包!

其实最简单的使用tar的记忆方法:
压 缩:tar -zcvvf filename.tar.gz 要被压缩的文件或目录名称
查 看: tar -ztvf filename.tar.gz
解压缩: tar -zxvf filename.tar.gz -C 欲解压缩的目录


二、示例讲解

tar示例一:将整个 /etc 目录下的文件全部打包成为 /tmp/etc.tar
[root@localhost ~]# tar -cvf /tmp/etc.tar /etc <==仅打包,不压缩!
[root@localhost ~]# tar -zcvf /tmp/etc.tar.gz /etc <==打包后,以 gzip 压缩
[root@localhost ~]# tar -jcvf /tmp/etc.tar.bz2 /etc <==打包后,以 bzip2 压缩
[root@localhost ~]# ls -lh /tmp
total 36M
-rw-r--r--. 1 root root 22M Dec 4 04:38 etc.tar
-rw-r--r--. 1 root root 6.6M Dec 4 04:38 etc.tar.bz2
-rw-r--r--. 1 root root 7.4M Dec 4 04:38 etc.tar.gz
# 特别注意,在参数 f 之后的文件档名是自己取的,我们习惯上都用 .tar 来作为辨识。
# 如果加 z 参数,则以 .tar.gz 或 .tgz 来代表 gzip 压缩过的 tar file ~
# 如果加 j 参数,则以 .tar.bz2 来作为附档名啊~
在备份重要的系统数据时,我们可以利用-p参数保留原本文件的权限与属性
# 上述指令在执行的时候,会显示一个警告讯息:
# 『tar: Removing leading `/' from member names』那是关於绝对路径的特殊设定。

tar例二:在打包一个文件时,一般从要打包的目录或文件的上一层目录对其打包
如果要打包这个文件和其绝对路径时,可以从/开始打包
[root@localhost ~]# tar -zcvf /tmp/etc1.tar.gz /tmp/dingjian <==打包其文件dingjian与绝对路径
tar: Removing leading `/' from member names
/tmp/dingjian/
/tmp/dingjian/aa
/tmp/dingjian/dd
/tmp/dingjian/cc
/tmp/dingjian/bb
[root@localhost ~]# cd /tmp <==在文件上一层目录只对这个dingjian这个文件进行打包
[root@localhost tmp]# tar -zcvf /tmp/etc2.tar.gz ./dingjian
./dingjian/
./dingjian/aa
./dingjian/dd
./dingjian/cc
./dingjian/bb
分别解压出来的路径:
[root@localhost ~]# ls
anaconda-ks.cfg dingjian install.log install.log.syslog tar.sh tmp
[root@localhost ~]# tar -zxvf /tmp/etc1.tar.gz
[root@localhost ~]# tree tmp
tmp
└── dingjian
├── aa
├── bb
├── cc
└── dd
[root@localhost ~]# tar -zxvf /tmp/etc2.tar.gz
1 directory,4 files
[root@localhost ~]# tree dingjian
dingjian
├── aa
├── bb
├── cc
└── dd

tar示例三:查阅上述 /tmp/目录中各打包文件内有哪些文件?
[root@localhost ~]# tar -tvf /tmp/etc.tar
[root@localhost ~]# tar -jtvf /tmp/etc.tar.bz2
[root@localhost ~]# tar -ztvf /tmp/etc.tar.gz
# 如果查看bz2 或gz压缩的文件就得要加上 j或z 这个参数了!这很重要的!

tar示例四:将 /tmp/etc.tar.gz 文件解压缩在 /usr/local/src 底下
[root@localhost /]# cd /usr/local/src
[root@localhost src]# tar -zxvf /tmp/etc.tar.gz
# 在预设的情况下,我们可以将压缩档在任何地方解开的!以这个范例来说,
# 我先将工作目录变换到 /usr/local/src 底下,并且解开 /tmp/etc.tar.gz ,
# 则解开的目录会在 /usr/local/src/etc 呢!另外,如果您进入 /usr/local/src/etc
# 则会发现,该目录下的文件属性与 /etc/ 可能会有所不同喔!

tar示例五:将/tmp/etc.tar.gz文件解压缩到指定的目录/root
[root@localhost ~]# tar -zxvf /tmp/etc.tar.gz -C /root
[root@localhost ~]# ls
anaconda-ks.cfg etc install.log install.log.syslog tar.sh

tar示例六:在 /tmp 底下,我只想要将 /tmp/etc.tar.gz 内的 etc/passwd 解开而已
[root@localhost tmp]# tar -ztvf etc.tar.gz |grep passwd
-rw-r--r-- root/root 146 2012-02-22 19:48 etc/pam.d/passwd
-rw-r--r-- root/root 1176 2013-11-05 05:52 etc/passwd-
-rw-r--r-- root/root 1176 2013-11-05 05:52 etc/passwd
-rw------- root/root 0 2013-02-22 08:16 etc/security/opasswd
[root@localhost tmp]# tar -zxvf /tmp/etc.tar.gz etc/passwd
etc/passwd
[root@localhost tmp]# ls -l etc
total 4
-rw-r--r--. 1 root root 1176 Nov 5 05:52 passwd
#我们通过tar -ztvf etc.tar.gz 结合管道grep来过滤找出passwd的所在位置
#在解压过程中etc/passwd不能客成/etc/passwd因为它是记录在etc.tar.gz内的文件名

tar示例七:将 /etc/ 内的所有文件备份下来,并且保存其权限!
[root@localhost ~]# tar -zxvpf /tmp/etc.tar.gz /etc
# 这个 -p 的属性是很重要的,尤其是当您要保留原本文件的属性时!

tar示例八:在 /etc 当中,比 2013/11/01 新的文件才备份
[root@localhost tmp]# tar -N '2013/11/01' -zcvf etc_2013.tar.gz /etc

tar示例九:打包备份当前目录下dingjian文件夹 ,但不打包里面linuxfile文件
[root@localhost tmp]# tree dingjian
dingjian
├── 11
├── 22
├── 33
├── 44
├── 55
├── aa
├── bb
├── cc
├── dd
├── ee
├── linuxfile
├── q1
├── q2
└── q3.4

5 directories,9 files
[root@localhost tmp]# tar --exclude ./dingjian/linuxfile -zcvf dingjian.tar.gz ./dingjian
./dingjian/
./dingjian/33/
./dingjian/aa
./dingjian/11/
./dingjian/55/
./dingjian/dd
./dingjian/ee
./dingjian/q2
./dingjian/cc
./dingjian/q1
./dingjian/bb
./dingjian/44/
./dingjian/q3.4
./dingjian/22/
[root@localhost tmp]# tar -ztvf dingjian.tar.gz
drwxr-xr-x root/root 0 2013-12-04 09:04 ./dingjian/
drwxr-xr-x root/root 0 2013-12-04 09:02 ./dingjian/33/
-rw-r--r-- root/root 0 2013-12-04 09:02 ./dingjian/aa
drwxr-xr-x root/root 0 2013-12-04 09:02 ./dingjian/11/
drwxr-xr-x root/root 0 2013-12-04 09:02 ./dingjian/55/
-rw-r--r-- root/root 0 2013-12-04 09:02 ./dingjian/dd
-rw-r--r-- root/root 0 2013-12-04 09:02 ./dingjian/ee
-rw-r--r-- root/root 0 2013-12-04 09:04 ./dingjian/q2
-rw-r--r-- root/root 0 2013-12-04 09:02 ./dingjian/cc
-rw-r--r-- root/root 0 2013-12-04 09:04 ./dingjian/q1
-rw-r--r-- root/root 0 2013-12-04 09:02 ./dingjian/bb
drwxr-xr-x root/root 0 2013-12-04 09:02 ./dingjian/44/
-rw-r--r-- root/root 0 2013-12-04 09:04 ./dingjian/q3.4
drwxr-xr-x root/root 0 2013-12-04 09:02 ./dingjian/22/

tar示例十:打包备份当前目录下dingjian文件夹 ,但不打包里面字每开头为q的文件
[root@localhost tmp]# tree dingjian
dingjian
├── 11
├── 22
├── 33
├── 44
├── 55
├── aa
├── bb
├── cc
├── dd
├── ee
├── linuxfile
├── q1
├── q2
└── q3.4
[root@localhost tmp]# tar --exclude=./dingjian/q* -zcvf myfile.tar.gz ./dingjian
./dingjian/
./dingjian/33/
./dingjian/aa
./dingjian/11/
./dingjian/55/
./dingjian/dd
./dingjian/ee
./dingjian/linuxfile
./dingjian/cc
./dingjian/bb
./dingjian/44/
./dingjian/22/
[root@localhost tmp]# tar -ztvf myfile.tar.gz
drwxr-xr-x root/root 0 2013-12-04 09:04 ./dingjian/
drwxr-xr-x root/root 0 2013-12-04 09:02 ./dingjian/33/
-rw-r--r-- root/root 0 2013-12-04 09:02 ./dingjian/aa
drwxr-xr-x root/root 0 2013-12-04 09:02 ./dingjian/11/
drwxr-xr-x root/root 0 2013-12-04 09:02 ./dingjian/55/
-rw-r--r-- root/root 0 2013-12-04 09:02 ./dingjian/dd
-rw-r--r-- root/root 0 2013-12-04 09:02 ./dingjian/ee
-rw-r--r-- root/root 0 2013-12-04 09:02 ./dingjian/linuxfile
-rw-r--r-- root/root 0 2013-12-04 09:02 ./dingjian/cc
-rw-r--r-- root/root 0 2013-12-04 09:02 ./dingjian/bb
drwxr-xr-x root/root 0 2013-12-04 09:02 ./dingjian/44/
drwxr-xr-x root/root 0 2013-12-04 09:02 ./dingjian/22/

tar实例十一:工作环境实例:
打包站点目录/var/www/html 备份到/data 目录下(最好每次备份按时间
生成不同的备份包)
[root@localhost tmp]# tar -zcvf html_$(date +%F).tar.gz /var/www/html
tar: Removing leading `/' from member names
/var/www/html/
[root@localhost tmp]# ls
html_2013-12-04.tar.gz

tar示例十二:将 /etc/ 打包后直接解开在 /tmp 底下,而不产生文件![root@localhost ~]# cd /tmp[root@localhost tmp]# tar -cvf - /etc | tar -xvf -# 这个动作有点像是 cp -r /etc /tmp 啦~依旧是有其有用途的!# 要注意的地方在於输出档变成 - 而输入档也变成 - ,又有一个 | 存在~# 这分别代表 standard output,standard input 与管线命令啦!

CentOS打包和解压详解的更多相关文章

  1. ios – Xcode警告:“没有处理文件的规则”和“找不到目录”

    重命名我的项目文件夹后,我收到以下错误消息:什么可能出错?解决方法关于第一个警告,您可以在项目设置中的“构建阶段”中检查XCode,即头文件不会出现在“编译源”列表中.

  2. 你如何将xcode项目转换为cocoapod?

    我有一段代码,我发现我在多个不同的项目中重复使用,所以我想把它变成一个cocoapod并使用私人cocoapod仓库.我的问题是如何将xcode项目设置为cocoapod?它应该是一个静态库还是一个带有appdelegate的空“项目”?

  3. ios – 如何将文件添加到主包的/ Library / Sounds目录中?

    根据Apple’sdocumentation,/Library/Sounds中的声音文件将在尝试播放声音时由系统搜索.如何将声音文件添加到此文件夹?适用于iOS的正确文档应为here总之,您只需将声音文件作为应用程序包的非本地化资源添加到项目中.

  4. ios – 资产目录与文件夹参考:何时使用其中一个?

    我可以将文件放入Assets.xcassets,或者我可以将文件放入文件夹引用.我何时会选择一个而不是另一个?

  5. ios – 从icloud备份中限制sqlite-wal和sqlite-shm

    我是第一次使用coredata,我必须从文档目录中的iCloud备份限制sqlitedb文件,我使用下面的代码完成了它//阻止iCloud备份文档目录文件夹现在我不明白的是,我们还需要从icloud备份中限制sqlite-wal和sqlite-shm文件,如果是,那么如何从icloud备份限制sqlite-wal和sqlite-shm文件我想要一个解决方案,而无需从文档目录文件夹中更改sqlitedb位置…

  6. iOS:如何从文档目录中删除具有特定扩展名的所有现有文件?

    当我更新我的iOS应用程序时,我想删除Documents目录中的任何现有sqlite数据库.现在,在应用程序更新时,我将数据库从软件包复制到文档目录,并通过附加软件包版本来命名它.因此,在更新时,我还想删除可能存在的任何旧版本.我只是希望能够删除所有sqlite文件,而无需循环浏览并查找以前版本的文件.是否有任何方法可以对removeFileAtPath:方法进行通配符?解决方法那么,你想要删除所有*.sqlite文件?

  7. .dylib在Debug中链接,在XCode中找不到适用于iPhone的版本

    所以我已经将libxml2.2.dylib库包含在我的iPhoneXCode项目中,以创建一些Xml和XPath解析实用程序.当我编译并运行在模拟器和设备的调试模式时,我没有问题,但是,当我切换到发布模式我得到…

  8. xcode7 – 谁在创建文件“/private/var/tmp/Untitled-*.uicatalog”?

    我正在调查为什么TeamCity构建代理程序用完了磁盘,并且在/private/var/tmp中找到了超过11,000个文件,它们都以Untitled-.uicatalog行命名.每个文件至少0.6MB.总磁盘占用空间约为4GB.这些文件可以追溯到几个月,所以他们能够重新启动.谁在创造他们?Xcode在编译至少有一个图像的xcassets目录时创建这些目录.我可以删除它们吗?

  9. ios – AFNetworking启用GZIP

    我在AFNetworking网站上查看支持GZIP压缩“服务器响应的Gzip解压缩已经内置在AFNetworking中,因为NSURLConnection将使用content-encoding:gzipHTTP头自动解压缩响应.”–AFNetworking常见问题如何启用GZIP压缩,以便我可以从服务器压缩数据或已经默认为谢谢!

  10. ios – 从文件目录加载UIImage

    我正在尝试从文件目录加载一个UIImage,并将其设置为UIImageView,如下所示:但是,每当我尝试以上,图像从不加载.该图像在Documents/MyAppCustomDirectory/school.png中.以上是否正确从该目录加载?我也尝试了其他几个:UIImageimageWithContentsOfFile,以及基于SO响应的其他方法.解决方法要获取您应该使用的文档目录:我不太清

随机推荐

  1. 在airgapped(离线)CentOS 6系统上安装yum软件包

    我有一个CentOS6系统,出于安全考虑,它已经被空气泄漏.它可能从未连接到互联网,如果有,它很长时间没有更新.我想将所有.rpm软件包放在一个驱动器上,这样它们就可以脱机安装而无需查询互联网.但是,我在测试VM上遇到的问题是,即使指定了本地路径,yum仍然会挂起并尝试从在线存储库进行更新.另外,有没有办法使用yum-utils/yumdownloader轻松获取该包的所有依赖项和所有依赖项?目前

  2. centos – 命名在日志旋转后停止记录到rsyslog

    CentOS6.2,绑定9.7.3,rsyslog4.6.2我最近设置了一个服务器,我注意到在日志轮换后,named已停止记录到/var/log/messages.我认为这很奇怪,因为所有日志记录都是通过rsyslog进行的,并且named不会直接写入日志文件.这更奇怪,因为我在更新区域文件后命名了HUPed,但它仍然没有记录.在我停止并重新启动命名后,记录恢复.这里发生了什么?

  3. centos – 显示错误的磁盘大小

    对于其中一个磁盘,Df-h在我的服务器上显示错误的空白区域:Cpanel表明它只有34GB免费,但还有更多.几分钟前,我删除了超过80GB的日志文件.所以,我确信它完全错了.fdisk-l/dev/sda2也显示错误:如果没有格式化,我该怎么做才能解决这个问题?并且打开文件描述符就是它需要使用才能做到这一点.所以…使用“lsof”并查找已删除的文件.重新启动写入日志文件的服务,你很可能会看到空间可用.

  4. 如何在centos 6.9上安装docker-ce 17?

    我目前正在尝试在centOS6.9服务器上安装docker-ce17,但是,当运行yuminstalldocker-ce时,我收到以下错误:如果我用跳过的标志运行它我仍然得到相同的消息,有没有人知道这方面的方法?

  5. centos – 闲置工作站的异常负载平均值

    我有一个新的工作站,具有不寻常的高负载平均值.机器规格是:>至强cpu>256GB的RAM>4x512GBSSD连接到LSI2108RAID控制器我从livecd安装了CentOS6.564位,配置了分区,网络,用户/组,并安装了一些软件,如开发工具和MATLAB.在启动几分钟后,工作站负载平均值的值介于0.5到0.9之间.但它没有做任何事情.因此我无法理解为什么负载平均值如此之高.你能帮我诊断一下这个问题吗?

  6. centos – Cryptsetup luks – 检查内核是否支持aes-xts-plain64密码

    我在CentOS5上使用cryptsetupluks加密加密了一堆硬盘.一切都很好,直到我将系统升级到CentOS6.现在我再也无法安装磁盘了.使用我的关键短语装载:我收到此错误:在/var/log/messages中:有关如何装载的任何想法?找到解决方案问题是驱动器使用大约512个字符长的交互式关键短语加密.出于某种原因,CentOS6中的新内核模块在由旧版本创建时无法正确读取512个字符的加密密钥.似乎只会影响内核或cryptsetup的不同版本,因为在同一系统上创建和打开时,512字符的密钥将起作用

  7. centos – 大量ssh登录尝试

    22个我今天登录CentOS盒找到以下内容这是过去3天内的11次登录尝试.WTF?请注意,这是我从我的提供商处获得的全新IP,该盒子是全新的.我还没有发布任何关于此框的内容.为什么我会进行如此大量的登录尝试?是某种IP/端口扫描?基本上有4名匪徒,其中2名来自中国,1名来自香港,1名来自Verizon.这只发生在SSH上.HTTP上没有问题.我应该将罪魁祸首子网路由吗?你们有什么建议?

  8. centos – kswap使用100%的CPU,即使有100GB的RAM也可用

    >Linux内核是否应该足够智能,只需从内存中清除旧缓存页而不是启动kswap?

  9. centos – Azure将VM从A2 / 3调整为DS2 v2

    我正在尝试调整前一段时间创建的几个AzureVM,从基本的A3和标准A3到标准的DS2v2.我似乎没有能力调整到这个大小的VM.必须从头开始重建服务器会有点痛苦.如果它有所不同我在VM中运行CentOS,每个都有一个带有应用程序和操作系统的磁盘.任何人都可以告诉我是否可以在不删除磁盘的情况下删除VM,创建新VM然后将磁盘附加到新VM?

  10. centos – 广泛使用RAM时服务器计算速度减慢

    我在非常具体的情况下遇到服务器速度下降的问题.事实是:>1)我使用计算应用WRF>2)我使用双XeonE5-2620v3和128GBRAM(NUMA架构–可能与问题有关!

返回
顶部