• 十一、tar打包命令的使用


    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 -zcvf filename.tar.gz 要被压缩的文件或目录名称
    查 看: tar -ztvf filename.tar.gz
    解压缩: tar -zxvf filename.tar.gz -C 欲解压缩的目录

    tar示例一:将整个 /etc 目录下的文件全部打包成为 /tmp/etc.tar

    [root@localhost.localdomain /tmp]# tar -cvf /tmp/etc.tar /etc    <==仅打包,不压缩!
    [root@localhost.localdomain /tmp]# tar -zcvf /tmp/etc.tar.gz /etc   <==打包后,以 gzip 压缩
    [root@localhost.localdomain /tmp]# tar -jcvf /tmp/etc.tar.bz2 /etc    <==打包后,以 bzip2 压缩
    
    [root@localhost.localdomain /tmp]# ls -l
    total 38212
    -rw-r--r--. 1 root root 28948480 Sep 24 15:16 etc.tar
    -rw-r--r--. 1 root root 0 Sep 24 15:18 etc.tar.bz2
    -rw-r--r--. 1 root root 10170259 Sep 24 15:16 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.localdomain /tmp]# mkdir /tmp/dingjian/aa{1..3} -p
    [root@localhost.localdomain /tmp]# tree dingjian/
    dingjian/
    ├── aa1
    ├── aa2
    └── aa3
    
    [root@localhost.localdomain /tmp]# tar -zcvf /tmp/etc1.tar.gz /tmp/dingjian  <==打包其文件dingjian与绝对路径
    tar: Removing leading `/' from member names
    /tmp/dingjian/
    /tmp/dingjian/aa1/
    /tmp/dingjian/aa2/
    /tmp/dingjian/aa3/
    
    [root@localhost.localdomain /tmp]# tar -zccvf /tmp/etc2.tar.gz ./dingjian    <==在文件上一层目录只对这个dingjian这个文件进行打包
    ./dingjian/
    ./dingjian/aa1/
    ./dingjian/aa2/
    ./dingjian/aa3/

    分别解压出来的路径:

    [root@localhost.localdomain /tmp]# tar -zxvf /tmp/etc1.tar.gz
    tmp/dingjian/
    tmp/dingjian/aa1/
    tmp/dingjian/aa2/
    tmp/dingjian/aa3/
    [root@localhost.localdomain /tmp]# tar -zxvf /tmp/etc2.tar.gz
    ./dingjian/
    ./dingjian/aa1/
    ./dingjian/aa2/
    ./dingjian/aa3/
    
    [root@localhost.localdomain /tmp]# ls -l
    total 8
    drwxr-xr-x. 5 root root 39 Sep 24 15:23 dingjian
    -rw-r--r--. 1 root root 152 Sep 24 15:25 etc1.tar.gz
    -rw-r--r--. 1 root root 153 Sep 24 15:25 etc2.tar.gz
    drwxr-xr-x. 3 root root 22 Sep 24 15:27 tmp
    [root@localhost.localdomain /tmp]# tree tmp
    tmp
    └── dingjian
    ├── aa1
    ├── aa2
    └── aa3
    
    4 directories, 0 files
    [root@localhost.localdomain /tmp]# tree dingjian/
    dingjian/
    ├── aa1
    ├── aa2
    └── aa3

    tar示例三:查阅上述 /tmp/目录中各打包文件内有哪些文件?

    [root@localhost.localdomain /tmp]# tar -tvf /tmp/etc.tar
    [root@localhost.localdomain /tmp]# tar -jtvf /tmp/etc.tar.bz2
    [root@localhost.localdomain /tmp]#  tar -ztvf /tmp/etc.tar.gz 

    # 如果查看bz2 或gz压缩的文件就得要加上 j或z 这个参数了!这很重要的!

    tar示例四:将 /tmp/etc.tar.gz 文件解压缩在 /usr/local/src 底下
    [root@localhost.localdomain /]# cd /usr/local/src
    [root@localhost.localdomain 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.localdomain ~]# tar -zxvf /tmp/etc.tar.gz -C /root
    [root@localhost.localdomain ~]# ls
    anaconda-ks.cfg etc install.log install.log.syslog tar.sh

    tar示例六:在 /tmp 底下,我只想要将 /tmp/etc.tar.gz 内的 etc/passwd 解开而已

    [root@localhost.localdomain 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.localdomain tmp]# tar -zxvf /tmp/etc.tar.gz etc/passwd
    etc/passwd
    [root@localhost.localdomain 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.localdomain ~]# tar -zxvpf /tmp/etc.tar.gz /etc
    # 这个 -p 的属性是很重要的,尤其是当您要保留原本文件的属性时!

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

    tar示例九:打包备份当前目录下dingjian文件夹 ,但不打包里面linuxfile文件

    [root@localhost.localdomain 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.localdomain 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.localdomain 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.localdomain  tmp]# tree dingjian
    dingjian
    ├── 11
    ├── 22
    ├── 33
    ├── 44
    ├── 55
    ├── aa
    ├── bb
    ├── cc
    ├── dd
    ├── ee
    ├── linuxfile
    ├── q1
    ├── q2
    └── q3.4
    [rroot@localhost.localdomain 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.localdomain  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.localdomain tmp]# tar -zcvf html_$(date +%F).tar.gz /var/www/html
    tar: Removing leading `/' from member names
    /var/www/html/
    [root@localhost.localdomain tmp]# ls
    html_2013-12-04.tar.gz

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

  • 相关阅读:
    Modelsim仿真笔记
    RTP协议
    SHFileOperation使用
    浅谈基于IP网络的H.264关键技术及应用
    jrtplib在windows下的编译步骤
    DEBUG AND RELEASE
    CTree 使用详解 转:
    VC中给树形控件的图标加上工具提示
    MFC六大关键技术之(二)——运行时类型识别(RTTI)
    Linux下编译jrtplib和jthread:
  • 原文地址:https://www.cnblogs.com/mr-xiong/p/13729354.html
Copyright © 2020-2023  润新知