百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

linux系统利用 tar 进行文件归档(linux中tar文件怎么解压)

nanshan 2024-10-09 13:01 10 浏览 0 评论

什么是文件归档?

文件归档就是将一组拥有相同属性的文件或目录组合到一个文件中,并从新存储它们到一个专门的目录中,以便以后在需要时进行查阅。比方说,很多情况下,我们的系统日志是有轮询的,旧的日志,会在一定的时间内会被自动删除,我们需要经常对日志进行归档,以保存旧的日志,以便我们在需要时进行查阅。

使用 tar 命令归档文件或目录

tar 可以将多个文件打包成一个文件,以便在网络上传输和归档,当你需要时,可以将他们提取出来。该归档文件还可以使用 gzipbzip2xz 压缩方式进行文件压缩。

使用 tar 命令对 /var/log/ 文件里面的 log 进行归档,其中 c 选项表示创建一个归档文件,f 选项用于指定归档文件的名称;

[root@websvr ~]# tar -cf log.tar /var/log/
tar: Removing leading `/' from member names
[root@websvr ~]# ls
log.tar
[root@websvr ~]#


* 在执行归档时,如果归档的目录包含根目录 ” / " ,则在归档的时候,会自定删除根目录,这样做的目的就是防止在提取文件时发生误操作,覆盖原文件,确保提取文件时,始终会是在当前目录。

如果你想在归档过程中显示归档的细节,归档了哪些文件,你可以通过添加 v 选项,来实现这一目的;

[root@websvr ~]# tar -cvf log1.tar /var/log/
tar: Removing leading `/' from member names
/var/log/
/var/log/lastlog
/var/log/private/
/var/log/wtmp
/var/log/samba/
/var/log/samba/old/
/var/log/audit/
/var/log/audit/audit.log.4
/var/log/audit/audit.log.3
/var/log/audit/audit.log.2
/var/log/audit/audit.log.1
/var/log/audit/audit.log
/var/log/spooler-20201101
/var/log/sssd/
/var/log/sssd/sssd_implicit_files.log-20200705.gz
/var/log/sssd/sssd_nss.log-20200705.gz
/var/log/sssd/sssd_implicit_files.log-20200712
... output omitted ...

如果你想查看归档文件中的具体内容,你可以使用 t 选项来查看 log.tar 文件中的内容;

[root@websvr ~]# tar -tf log.tar
var/log/
var/log/lastlog
var/log/private/
var/log/wtmp
var/log/samba/
var/log/samba/old/
var/log/audit/
var/log/audit/audit.log.4
var/log/audit/audit.log.3
var/log/audit/audit.log.2
var/log/audit/audit.log.1
var/log/audit/audit.log
var/log/spooler-20201101
var/log/sssd/
var/log/sssd/sssd_implicit_files.log-20200705.gz
var/log/sssd/sssd_nss.log-20200705.gz
var/log/sssd/sssd_implicit_files.log-20200712
... output omitted ...

当需要时,我们可以使用 x 选项来提取 log.tar 中的文件

[root@websvr ~]# mkdir log
[root@websvr ~]# cd log/
[root@websvr log]# tar -xf ~/log.tar 
[root@websvr log]# ls
var
[root@websvr log]# ls var/
log
[root@websvr log]# ls var/log/
anaconda               cron                      dnf.log.2                     httpd              messages-20201018  spooler
audit                  cron-20201011             dnf.log.3                     insights-client    messages-20201025  spooler-20201011
boot.log               cron-20201018             dnf.log.4                     journal            messages-20201101  spooler-20201018
boot.log-20200622      cron-20201025             dnf.rpm.log                   lastlog            php-fpm            spooler-20201025
boot.log-20200629      cron-20201101             ecs_network_optimization.log  maillog            private            spooler-20201101
boot.log-20200706      dnf.librepo.log           exim                          maillog-20201011   sa                 sssd
btmp                   dnf.librepo.log-20201011  grafana                       maillog-20201018   samba              tuned
btmp-20201101          dnf.librepo.log-20201018  hawkey.log                    maillog-20201025   secure             wtmp
chrony                 dnf.librepo.log-20201025  hawkey.log-20201011           maillog-20201101   secure-20201011    zabbix
cloudinit-deploy.log   dnf.librepo.log-20201101  hawkey.log-20201018           mariadb            secure-20201018
cloud-init.log         dnf.log                   hawkey.log-20201025           messages           secure-20201025
cloud-init-output.log  dnf.log.1                 hawkey.log-20201101           messages-20201011  secure-20201101

压缩存档文件

当我们要归档的文件比较大时,或者我们想在网络上传输我们的归档文件,这个时候,我们需要在归档文件的时候,对文件进行一个压缩,从而减少对带宽的要求。

tar 支持三种压缩方式:

  • gzip 压缩速度最快,使用最广泛,但压缩率相对较低
  • bzip2 压缩文件通常会比 gzip 要小,但使用没有 gzip广泛
  • xz 相对比较新,但压缩率是三个中最高的

创建压缩文件选项:

  • 通过 -z 选项创建 gzip 方式的压缩文件(*.tar.gz 或 *.tgz)
  • 通过 -j 选项创建 bzip 方式的压缩文件(*.tar.bz2)
  • 使用 -J 选项创建 xz 方式的压缩文件(*.tar.xz)

创建 gzip 格式的压缩存档

[root@websvr ~]# tar -czf log.tar.gz /var/log/
tar: Removing leading `/' from member names
[root@websvr ~]# ls -lh log*
-rw-r--r-- 1 root root 760M Nov  6 08:16 log.tar
-rw-r--r-- 1 root root  97M Nov  6 08:15 log.tar.gz
  • 通过比较发现压缩后的文件,比之前的小

资源使用率

top - 16:54:46 up 16:18,  2 users,  load average: 0.80, 0.59, 0.30
Tasks: 120 total,   2 running, 118 sleeping,   0 stopped,   0 zombie
%Cpu(s): 35.3 us, 11.0 sy,  0.0 ni, 43.1 id,  0.0 wa,  0.0 hi,  0.1 si, 10.4 st
MiB Mem :   1829.0 total,     80.7 free,    179.5 used,   1568.8 buff/cache
MiB Swap:      0.0 total,      0.0 free,      0.0 used.   1486.0 avail Mem 

  PID USER      PR  NI    VIRT    RES    SHR S  %CPU  %MEM     TIME+ COMMAND               
 1952 student   20   0    4604   1396   1108 S  83.6   0.1   0:11.27 gzip                  
 1951 student   20   0  247172   2884   2680 R  17.7   0.2   0:02.37 tar                   
   39 root      20   0       0      0      0 S   2.7   0.0   0:04.20 kswapd0               
 1755 root      20   0       0      0      0 I   0.1   0.0   0:00.22 kworker/0:0-events   

压缩文件所需的时间(30 个文件,每个文件 100M)

[root@websvr ~]# time tar -czf test.tar2.gz test_file*

real 0m29.983s
user 0m23.198s
sys 0m7.041s

创建 bzip2 格式的压缩存档

[root@websvr ~]# tar -cjf log.tar.bz2 /var/log/
tar: Removing leading `/' from member names
[root@websvr ~]# ls -lh log*
-rw-r--r-- 1 root root 760M Nov  6 08:16 log.tar
-rw-r--r-- 1 root root  81M Nov  6 08:21 log.tar.bz2
-rw-r--r-- 1 root root  97M Nov  6 08:15 log.tar.gz

  • 压缩率虽然比 gzip 的高,但高的不是很多

资源使用率

top - 16:52:56 up 16:16,  2 users,  load average: 0.44, 0.46, 0.22
Tasks: 120 total,   4 running, 116 sleeping,   0 stopped,   0 zombie
%Cpu(s): 43.7 us,  7.2 sy,  0.0 ni, 43.8 id,  0.1 wa,  0.0 hi,  0.0 si,  5.2 st
MiB Mem :   1829.0 total,     71.2 free,    186.4 used,   1571.4 buff/cache
MiB Swap:      0.0 total,      0.0 free,      0.0 used.   1479.0 avail Mem 

  PID USER      PR  NI    VIRT    RES    SHR S  %CPU  %MEM     TIME+ COMMAND               
 1949 student   20   0   13784   8592   1228 R  93.0   0.5   0:13.67 bzip2                 
 1948 student   20   0  247172   2732   2528 R   9.9   0.1   0:01.54 tar                   
   39 root      20   0       0      0      0 S   1.1   0.0   0:03.22 kswapd0               
  448 root      20   0       0      0      0 S   0.1   0.0   0:01.60 xfsaild/vda1          
 1950 root      20   0       0      0      0 I   0.1   0.0   0:00.01 kworker/1:2-mm_percp+ 

压缩文件所需的时间(30 个文件,每个文件 100M)

[root@websvr ~]# time tar -cjf test.tar3.bz2 test_file*

real 1m10.511s
user 1m1.819s
sys 0m10.762s

创建 xz 格式的压缩存档

[root@websvr ~]# tar -cJf log.tar.xz /var/log/
tar: Removing leading `/' from member names
[root@websvr ~]# ls -lh log*
-rw-r--r-- 1 root root 760M Nov  6 08:16 log.tar
-rw-r--r-- 1 root root  81M Nov  6 08:21 log.tar.bz2
-rw-r--r-- 1 root root  97M Nov  6 08:15 log.tar.gz
-rw-r--r-- 1 root root  50M Nov  6 08:29 log.tar.xz
  • 通过比较,xz 格式的压缩比最高,但压缩的时间也是最长的

资源的使用率

top - 16:51:36 up 16:15,  2 users,  load average: 0.94, 0.53, 0.22
Tasks: 120 total,   4 running, 116 sleeping,   0 stopped,   0 zombie
%Cpu(s): 45.2 us,  5.4 sy,  0.0 ni, 44.0 id,  0.0 wa,  0.0 hi,  0.0 si,  5.4 st
MiB Mem :   1829.0 total,     62.9 free,    259.0 used,   1507.1 buff/cache
MiB Swap:      0.0 total,      0.0 free,      0.0 used.   1406.3 avail Mem 

  PID USER      PR  NI    VIRT    RES    SHR S  %CPU  %MEM     TIME+ COMMAND               
 1946 student   20   0  316704  81244   2200 R  97.5   4.3   1:39.23 xz                    
 1945 student   20   0  247172   2828   2620 R   9.3   0.2   0:09.75 tar                   
   39 root      20   0       0      0      0 S   0.8   0.0   0:02.98 kswapd0               
   30 root      39  19       0      0      0 S   0.5   0.0   0:00.57 khugepaged            
 1942 root      20   0       0      0      0 R   0.1   0.0   0:00.31 kworker/1:0-events   

压缩文件所需的时间(30 个文件,每个文件 100M)

[root@websvr ~]# time tar -cJf test.tar3.xz test_file*

real 1m49.429s
user 1m40.588s
sys 0m16.924s

总结

对于归档文件的压缩,压缩率最高的是 xz 格式的,但它也是用时最多,消耗资源最多的;时间最快的是 gzip 并且它也是消耗资源最少的,但是它的压缩率不是没有另外两个高;bzip2 不管是时间和资源的消耗,还是压缩率,在这三个都是居中,不过,对于时间,它相比 xz 少的不是很多,压缩率,相比 gzip 也不是很高,所有适用的场景不是很多。

相关推荐

提升网络安全 cisco asa5512-k8防火墙促

(中关村在线网络安全行情)ciscoasa5512-k8为标准下一代防火墙,能够为中小型网络提供出色的安全防护和流量管控服务。最近这款防火墙设备在京东商城的促销价格为14299元,有需要的用户可以关注...

太一星晨:负载均衡性能参数如何测评?

海外网2014-08-0816:03:568月6日消息,当前,在云计算和大数据为主导的需求环境下,负载均衡和应用交付已为大型企业数据中心“保驾护航”的必备品。不过,负载均衡作为一种比较“新奇”的设备...

Nginx架构揭秘:如何用5大核心机制扛住百万级并发

1.灵魂拷问:为什么全球Top1000网站中65%选择Nginx?17Nginx不仅是Web服务器,更是高并发架构的核武器。其单机支持10万+并发连接的秘密,源于三大设计哲学:事件驱动模型:非阻塞...

高并发场景下,Nginx性能如何提升10倍?

大家好,我是mikechen。在高并发场景,Nginx是流量入口的第一道防线,如果想拦截亿级流量,需要Nginx合理调优才能应对@mikechen。本文作者:陈睿|mikechen文章来源:mike...

紧急避坑!数据库突现数十GB临时文件?原因与根治方案揭秘

引言:某天深夜,运维小王突然收到磁盘爆满的告警,追踪发现Kingbase数据库的syssql_tmp目录竟堆积了数十GB的临时文件!这些神秘文件为何产生?会引发哪些风险?如何彻底根治?本文将带你深入探...

互联网大厂后端必看!3 步搞定 Nginx IP 限流,服务器扛住百万流量

作为互联网大厂的后端开发人员,你是否曾遇到过这样的场景:服务器突然涌入大量请求,服务响应速度急剧下降,甚至出现崩溃?这时候,Nginx的IP访问限流策略就显得尤为重要。然而,不少开发者在配置N...

MySQL max_connections 达到最大值 – 我们如何解决它

您的网站是否显示MySQLmax_connections达到最大限制错误?通常,当我们尝试连接到MySQL服务器时,MySQLmax_connections值不足会导致“Tooma...

Nginx百万并发背后技术揭秘!(nginx并发能力是多少)

在互联网业务高速发展的今天,用户访问量呈指数级增长,服务器面临的并发压力也越来越大。一个高并发的网站,如果处理不当,可能会出现请求超时、服务器宕机、用户体验下降等问题。Nginx作为当前最流行的高性...

Nginx底层原理:一文解析Nginx为什么并发数可以达到3w!

Nginx以其高性能,稳定性,丰富的功能,简单的配置和低资源消耗而闻名。本文从底层原理分析Nginx为什么这么快!Nginx的进程模型Nginx服务器,正常运行过程中:多进程:一个Mast...

Nginx合集-并发连接能力优化(nginx高并发调优)

一、前言nginx服务器老是报告TIME_WAIT告警,ESTABLISHED告警,检查nginx配置和系统网络配置发现现有的配置并发能力太弱,无法满足现有的并发请求的需求。二、解决方法改进方法...

开源OS上安装Gnome Flashback经典桌面

1安装GnomeFlashback对于用户来说,相比Unity桌面,GnomeFlashback桌面环境是一个简单的并且不错的选择,可以让你找回过去经典的桌面。GnomeFlashback基于G...

新手篇 — 虚拟机系统的使用与常见问题

本文章会详细介绍虚拟机系统的使用与常见问题,有很多读者都会遇到这样的情况,软件装不上,自己的电脑中软件很多,又不想换电脑系统,那么虚拟机可以帮你解决这个烦恼,由于文章内容写的比较详细,内容会比较多,可...

VMware虚拟机与主机之间无法复制粘贴解决

问题:VMware安装系统后发现无法直接与主机之间进行复制粘贴了,怎么办?解决办法:按照以下3步进行1、设置中客户机隔离检查2、重新安装VMwareTools3、重启电脑...

实现VMware虚拟机与物理主机共享文件夹

在安装虚拟机之后,难免会遇到需要将文件从主机拷到虚拟机当中,但是很尴尬的事情就是不能直接将文件从主机拖到虚拟机中,所以只能借助U盘,但是频繁的插拔U盘非常的繁琐。为了解决这一需求,就可以将物理主机和...

在 Windows 11 或 10 上安装 Virt-viewer 的单行命令

Virt-Viewer(或RemoteViewer)是Redhat提供的一个开源程序,允许用户控制和查看运行在本地或远程服务器上的虚拟机。它体积轻巧,并提供了一个简单的图形用户界面来访问由L...

取消回复欢迎 发表评论: