Linux系统之Tar打包与压缩文件

简介: Linux系统之Tar打包与压缩文件

一、tar命令介绍

1.tar命令简介

tar 是用来建立,还原备份文件的工具程序,它可以加入,解开备份文件内的文件。

2.tar命令的语法

[root@docker showdoc]# tar --help
Usage: tar [OPTION...] [FILE]...

3.tar命令帮助

参数:

-A或--catenate 新增文件到已存在的备份文件。
-b<区块数目>或--blocking-factor=<区块数目> 设置每笔记录的区块数目,每个区块大小为12Bytes。
-B或--read-full-records 读取数据时重设区块大小。
-c或--create 建立新的备份文件。
-C<目的目录>或--directory=<目的目录> 切换到指定的目录。
-d或--diff或--compare 对比备份文件内和文件系统上的文件的差异。
-f<备份文件>或--file=<备份文件> 指定备份文件。
-F<Script文件>或--info-script=<Script文件> 每次更换磁带时,就执行指定的Script文件。
-g或--listed-incremental 处理GNU格式的大量备份。
-G或--incremental 处理旧的GNU格式的大量备份。
-h或--dereference 不建立符号连接,直接复制该连接所指向的原始文件。
-i或--ignore-zeros 忽略备份文件中的0 Byte区块,也就是EOF。
-k或--keep-old-files 解开备份文件时,不覆盖已有的文件。
-K<文件>或--starting-file=<文件> 从指定的文件开始还原。
-l或--one-file-system 复制的文件或目录存放的文件系统,必须与tar指令执行时所处的文件系统相同,否则不予复制。
-L<媒体容量>或-tape-length=<媒体容量> 设置存放每体的容量,单位以1024 Bytes计算。
-m或--modification-time 还原文件时,不变更文件的更改时间。
-M或--multi-volume 在建立,还原备份文件或列出其中的内容时,采用多卷册模式。
-N<日期格式>或--newer=<日期时间> 只将较指定日期更新的文件保存到备份文件里。
-o或--old-archive或--portability 将资料写入备份文件时使用V7格式。
-O或--stdout 把从备份文件里还原的文件输出到标准输出设备。
-p或--same-permissions 用原来的文件权限还原文件。
-P或--absolute-names 文件名使用绝对名称,不移除文件名称前的"/"号。
-r或--append 新增文件到已存在的备份文件的结尾部分。
-R或--block-number 列出每个信息在备份文件中的区块编号。
-s或--same-order 还原文件的顺序和备份文件内的存放顺序相同。
-S或--sparse 倘若一个文件内含大量的连续0字节,则将此文件存成稀疏文件。
-t或--list 列出备份文件的内容。
-T<范本文件>或--files-from=<范本文件> 指定范本文件,其内含有一个或多个范本样式,让tar解开或建立符合设置条件的文件。
-u或--update 仅置换较备份文件内的文件更新的文件。
-U或--unlink-first 解开压缩文件还原文件之前,先解除文件的连接。
-v或--verbose 显示指令执行过程。
-V<卷册名称>或--label=<卷册名称> 建立使用指定的卷册名称的备份文件。
-w或--interactive 遭遇问题时先询问用户。
-W或--verify 写入备份文件后,确认文件正确无误。
-x或--extract或--get 从备份文件中还原文件。
-X<范本文件>或--exclude-from=<范本文件> 指定范本文件,其内含有一个或多个范本样式,让ar排除符合设置条件的文件。
-z或--gzip或--ungzip 通过gzip指令处理备份文件。
-Z或--compress或--uncompress 通过compress指令处理备份文件。
-<设备编号><存储密度> 设置备份用的外围设备编号及存放数据的密度。
--after-date=<日期时间> 此参数的效果和指定"-N"参数相同。
--atime-preserve 不变更文件的存取时间。
--backup=<备份方式>或--backup 移除文件前先进行备份。
--checkpoint 读取备份文件时列出目录名称。
--concatenate 此参数的效果和指定"-A"参数相同。
--confirmation 此参数的效果和指定"-w"参数相同。
--delete 从备份文件中删除指定的文件。
--exclude=<范本样式> 排除符合范本样式的文件。
--group=<群组名称> 把加入设备文件中的文件的所属群组设成指定的群组。
--help 在线帮助。
--ignore-failed-read 忽略数据读取错误,不中断程序的执行。
--new-volume-script=<Script文件> 此参数的效果和指定"-F"参数相同。
--newer-mtime 只保存更改过的文件。
--no-recursion 不做递归处理,也就是指定目录下的所有文件及子目录不予处理。
--null 从null设备读取文件名称。
--numeric-owner 以用户识别码及群组识别码取代用户名称和群组名称。
--owner=<用户名称> 把加入备份文件中的文件的拥有者设成指定的用户。
--posix 将数据写入备份文件时使用POSIX格式。
--preserve 此参数的效果和指定"-ps"参数相同。
--preserve-order 此参数的效果和指定"-A"参数相同。
--preserve-permissions 此参数的效果和指定"-p"参数相同。
--record-size=<区块数目> 此参数的效果和指定"-b"参数相同。
--recursive-unlink 解开压缩文件还原目录之前,先解除整个目录下所有文件的连接。
--remove-files 文件加入备份文件后,就将其删除。
--rsh-command=<执行指令> 设置要在远端主机上执行的指令,以取代rsh指令。
--same-owner 尝试以相同的文件拥有者还原文件。
--suffix=<备份字尾字符串> 移除文件前先行备份。
--totals 备份文件建立后,列出文件大小。
--use-compress-program=<执行指令> 通过指定的指令处理备份文件。
--version 显示版本信息。
--volno-file=<编号文件> 使用指定文件内的编号取代预设的卷册编号。

二、tar打包和解压缩分开使用

1.tar打包目录

tar  -cvf etc.tar /etc

2.gzip压缩etc.tar

[root@docker ~]# ll
total 10988
-rw-------. 1 root root     1380 Oct  1 21:45 anaconda-ks.cfg
drwxr-xrwx  7 root root       86 Oct 23 22:08 data
-rw-r--r--  1 root root 11218467 Oct 24 00:31 etc.tar.gz

3.解压etc.tar.gz

[root@docker ~]# gunzip etc.tar.gz 
[root@docker ~]# ll
total 32432
-rw-------. 1 root root     1380 Oct  1 21:45 anaconda-ks.cfg
drwxr-xrwx  7 root root       86 Oct 23 22:08 data
-rw-r--r--  1 root root 33177600 Oct 24 00:31 etc.tar
-rw-r--r--  1 root root    19873 Oct 20 18:57 get-docker.sh

4.将etc.tar文件解包

tar -xvf etc.tar

5.查看最后解压缩的文件夹

[root@docker ~]# ll
total 32444
-rw-------.  1 root root     1380 Oct  1 21:45 anaconda-ks.cfg
drwxr-xrwx   7 root root       86 Oct 23 22:08 data
drwxr-xr-x  79 root root     8192 Oct 21 13:54 etc
-rw-r--r--   1 root root 33177600 Oct 24 00:31 etc.tar
-rw-r--r--   1 root root    19873 Oct 20 18:57 get-docker.sh

三、直接使用tar解压缩操作

1.将/etc 打包并压缩为 etc.tar.gz

[root@docker ~]# tar -czf  etc.tar.gz  /etc
tar: Removing leading `/' from member names
tar: /etc/.vmtools/GuestAgent.domain: socket ignored
tar: /etc/.vmtools/ParaNoDisk.domain: socket ignored
[root@docker ~]# ll
total 10980
-rw-------. 1 root root     1380 Oct  1 21:45 anaconda-ks.cfg
drwxr-xrwx  7 root root       86 Oct 23 22:08 data
-rw-r--r--  1 root root 11218459 Oct 24 00:42 etc.tar.gz
-rw-r--r--  1 root root    19873 Oct 20 18:57 get-docker.sh

2.将 etc.tar.gz 文件解压缩

[root@docker ~]# tar -xzf etc.tar.gz  -C /tmp
[root@docker ~]# ll /tmp
total 12
drwxr-xr-x 79 root root 8192 Oct 21 13:54 etc
[root@docker ~]# 

四、日常工作的tar备份

1.使用gzip方式备份

tar -zcvf test.tar.gz ./test # 得到test.tar.gz备份文件

image.png

2.使用bzip2方式备份

tar -jcvf test.tar.bz2 ./test # 得到test.tar.bz2备份文件

image.png

3.查看备份文件中的文件

[root@docker ~]# tar -tf data.tar.gz  |head
data/
data/cms/
data/cms/docker-compose.yaml
data/filemanager/
data/filemanager/files/
data/filemanager/files/aa1/
data/filemanager/files/aa1/file11
data/filemanager/files/aa1/file12
data/filemanager/files/aa1/file13
data/filemanager/files/aa1/file14

4.查看备份文件中的文件详细信息


[root@docker ~]# tar -tvf data.tar.gz  |head
drwxr-xr-x root/root         0 2022-10-23 22:36 data/
drwxr-xr-x root/root         0 2022-10-20 20:12 data/cms/
-rw-r--r-- root/root       700 2022-10-20 20:12 data/cms/docker-compose.yaml
drwxr-xr-x root/root         0 2022-10-21 15:26 data/filemanager/
drwxrwxrwx root/root         0 2022-10-21 15:14 data/filemanager/files/
drwxrwxrwx root/root         0 2022-10-21 15:14 data/filemanager/files/aa1/
-rwxrwxrwx root/root         0 2022-10-21 15:14 data/filemanager/files/aa1/file11
-rwxrwxrwx root/root         0 2022-10-21 15:14 data/filemanager/files/aa1/file12
-rwxrwxrwx root/root         0 2022-10-21 15:14 data/filemanager/files/aa1/file13
-rwxrwxrwx root/root         0 2022-10-21 15:14 data/filemanager/files/aa1/file14
相关文章
|
20天前
|
Linux Shell 网络安全
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
本指南介绍如何利用 HTA 文件和 Metasploit 框架进行渗透测试。通过创建反向 shell、生成 HTA 文件、设置 HTTP 服务器和发送文件,最终实现对目标系统的控制。适用于教育目的,需合法授权。
53 9
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
|
6天前
|
Ubuntu Linux Go
golang编译成Linux可运行文件
本文介绍了如何在 Linux 上编译和运行 Golang 程序,涵盖了本地编译和交叉编译的步骤。通过这些步骤,您可以轻松地将 Golang 程序编译成适合 Linux 平台的可执行文件,并在目标服务器上运行。掌握这些技巧,可以提高开发和部署 Golang 应用的效率。
63 14
|
5天前
|
存储 NoSQL Linux
linux积累-core文件是干啥的
核心文件是Linux系统在程序崩溃时生成的重要调试文件,通过分析核心文件,开发者可以找到程序崩溃的原因并进行调试和修复。本文详细介绍了核心文件的生成、配置、查看和分析方法
31 6
|
7天前
|
存储 NoSQL Linux
linux之core文件如何查看和调试
通过设置和生成 core 文件,可以在程序崩溃时获取详细的调试信息。结合 GDB 等调试工具,可以深入分析 core 文件,找到程序崩溃的具体原因,并进行相应的修复。掌握这些调试技巧,对于提高程序的稳定性和可靠性具有重要意义。
44 6
|
2月前
|
Linux 开发工具 Perl
在Linux中,有一个文件,如何删除包含“www“字样的字符?
在Linux中,如果你想删除一个文件中包含特定字样(如“www”)的所有字符或行,你可以使用多种文本处理工具来实现。以下是一些常见的方法:
43 5
|
8月前
|
缓存 Linux 测试技术
安装【银河麒麟V10】linux系统--并挂载镜像
安装【银河麒麟V10】linux系统--并挂载镜像
2226 0
|
8月前
|
关系型数据库 MySQL Linux
卸载、下载、安装mysql(Linux系统centos7)
卸载、下载、安装mysql(Linux系统centos7)
255 0
|
3月前
|
Linux
手把手教会你安装Linux系统
手把手教会你安装Linux系统
|
6月前
|
Linux 虚拟化 数据安全/隐私保护
部署05-VMwareWorkstation中安装CentOS7 Linux操作系统, VMware部署CentOS系统第一步,下载Linux系统,/不要忘, CentOS -7-x86_64-DVD
部署05-VMwareWorkstation中安装CentOS7 Linux操作系统, VMware部署CentOS系统第一步,下载Linux系统,/不要忘, CentOS -7-x86_64-DVD
|
4月前
|
Ubuntu Linux 网络安全
从头安装Arch Linux系统
本文记录了作者安装Arch Linux系统的过程,包括安装成果展示和遇到的疑难点及其解决方法,如硬盘不足、下载失败、设置时区、安装微码和配置无密码登录等。
101 1
从头安装Arch Linux系统