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
相关文章
|
1天前
|
弹性计算 Shell Linux
查找 Linux 系统中的僵尸进程
【4月更文挑战第28天】
5 0
|
3天前
|
SQL 监控 架构师
linux系统性能分析的目的
【4月更文挑战第19天】在Linux系统中,找到性能瓶颈是关键,涉及应用程序、操作系统、硬件和网络的全面排查。优化方案通常针对应用程序和操作系统,而硬件和网络问题较易定位。目标是平衡资源使用,确保系统响应和稳定性。系统管理员、架构设计人员和开发人员共同参与,通过监控硬件、网络、配置和代码来优化性能。流程包括管理员初步判断,架构师处理结构问题,开发人员优化代码,实现系统资源的均衡利用。
13 1
|
5天前
|
Ubuntu Linux
Linux(Ubuntu)系统临时IP以及静态IP配置(关闭、启动网卡等操作)
请注意,以上步骤是在临时基础上进行配置的。如果要永久保存静态IP地址,通常还需要修改 `/etc/network/interfaces`文件,以便在系统重启后保持配置。同时,确保备份相关配置文件以防止出现问题。
22 1
|
6天前
|
Linux 数据安全/隐私保护
Linux系统忘记密码的三种解决办法
这篇博客介绍了三种在Linux忘记密码时重置登录密码的方法:1) 使用恢复模式,通过控制台界面以管理员权限更改密码;2) 利用Linux Live CD/USB启动,挂载硬盘分区并使用终端更改密码;3) 进入单用户模式,自动以管理员身份登录后重置密码。每个方法都提供了详细步骤,提醒用户在操作前备份重要数据。
|
6天前
|
JSON Unix Linux
Linux系统之jq工具的基本使用
Linux系统之jq工具的基本使用
32 2
|
6天前
|
数据采集 监控 安全
linux系统被×××后处理经历
linux系统被×××后处理经历
|
6天前
|
监控 安全 Linux
Linux系统之安装ServerBee服务器监控工具
【4月更文挑战第22天】Linux系统之安装ServerBee服务器监控工具
45 2
|
4月前
|
NoSQL Java Linux
Linux常用命令(文件目录操作、拷贝移动、打包压缩、文本编辑、查找)
Linux常用命令(文件目录操作、拷贝移动、打包压缩、文本编辑、查找)
|
4月前
|
Linux
linux(二十七)打包压缩命令bzip2~
linux(二十七)打包压缩命令bzip2~
35 0
|
2月前
|
Linux Windows
Linux:为什么要打包和压缩?
Linux:为什么要打包和压缩?
Linux:为什么要打包和压缩?