Linux下的tar压缩解压缩命令详解

时间:2024-10-10 07:31:25

tar -xZvf    //解压

unrar e //解压rar

unzip //解压zip

总结

1、*.tar 用 tar -xvf 解压

2、*.gz 用 gzip -d或者gunzip 解压

3、*.和*.tgz 用 tar -xzf 解压

4、*.bz2 用 bzip2 -d或者用bunzip2 解压

5、*.tar.bz2用tar -xjf 解压

6、*.Z 用 uncompress 解压

7、*. 用tar -xZf 解压

8、*.rar 用 unrar e解压

9、*.zip 用 unzip 解压

解压jdk到指定文件夹

tar -xzvf jdk-8u131-linux- -C /usr/local/java

root@ubuntu:~# tar --help

用法: tar [选项…] [FILE]…

GNU ‘tar’ saves many files together into a single tape or disk archive, and can

restore individual files from the archive.

Examples:

tar -cf foo bar # Create from files foo and bar.

tar -tvf # List all files in verbosely.

tar -xf # Extract all files from .

主操作模式:

-A, --catenate, --concatenate 追加 tar 文件至归档

-c, --create 创建一个新归档

-d, --diff, --compare 找出归档和文件系统的差异

–delete 从归档(非磁带!)中删除

-r, --append 追加文件至归档结尾

-t, --list 列出归档内容

–test-label 测试归档卷标并退出

-u, --update 仅追加比归档中副本更新的文件

-x, --extract, --get 从归档中解出文件

操作修饰符:

–check-device 当创建增量归档时检查设备号(默认)

-g, --listed-incremental=FILE 处理新式的 GNU 格式的增量备份

-G, --incremental 处理老式的 GNU 格式的增量备份

–ignore-failed-read

当遇上不可读文件时不要以非零值退出

–level=NUMBER 所创建的增量列表归档的输出级别

-n, --seek 归档可检索

–no-check-device 当创建增量归档时不要检查设备号

–no-seek 归档不可检索

–occurrence[=NUMBER] 仅处理归档中每个文件的第 NUMBER

个事件;仅当与以下子命令 --delete,

–diff, --extract 或是 --list

中的一个联合使用时,此选项才有效。而且不管文件列表是以命令行形式给出或是通过

-T 选项指定的;NUMBER 值默认为 1

–sparse-version=MAJOR[.MINOR]

设置所用的离散格式版本(隐含

–sparse)

-S, --sparse 高效处理离散文件

重写控制:

-k, --keep-old-files don’t replace existing files when extracting,

treat them as errors

–keep-directory-symlink preserve existing symlinks to directories when

extracting

–keep-newer-files

不要替换比归档中副本更新的已存在的文件

–no-overwrite-dir 保留已存在目录的元数据

–one-top-level[=DIR] create a subdirectory to avoid having loose files

extracted

–overwrite 解压时重写存在的文件

–overwrite-dir 解压时重写已存在目录的元数据(默认)

–recursive-unlink 解压目录之前先清除目录层次

–remove-files 在添加文件至归档后删除它们

–skip-old-files don’t replace existing files when extracting,

silently skip over them

-U, --unlink-first 在解压要重写的文件之前先删除它们

-W, --verify 在写入以后尝试校验归档

选择输出流:

–ignore-command-error 忽略子进程的退出代码

–no-ignore-command-error

将子进程的非零退出代码认为发生错误

-O, --to-stdout 解压文件至标准输出

–to-command=COMMAND

将解压的文件通过管道传送至另一个程序

操作文件属性:

–atime-preserve[=METHOD]

在输出的文件上保留访问时间,要么通过在读取(默认

METHOD=‘replace’)后还原时间,要不就不要在第一次(METHOD=‘system’)设置时间

–clamp-mtime only set time when the file is more recent than

what was given with --mtime

–delay-directory-restore

直到解压结束才设置修改时间和所解目录的权限

–group=名称 强制将 NAME

作为所添加的文件的组所有者

–mode=CHANGES 强制将所添加的文件(符号)更改为权限

CHANGES

–mtime=DATE-OR-FILE 从 DATE-OR-FILE 中为添加的文件设置

mtime

-m, --touch 不要解压文件的修改时间

–no-delay-directory-restore

取消 --delay-directory-restore 选项的效果

–no-same-owner

将文件解压为您所有(普通用户默认此项)

–no-same-permissions

从归档中解压权限时使用用户的掩码位(默认为普通用户服务)

–numeric-owner 总是以数字代表用户/组的名称

–owner=名称 强制将 NAME

作为所添加的文件的所有者

-p, --preserve-permissions, --same-permissions

解压文件权限信息(默认只为超级用户服务)

–preserve 与 -p 和 -s 一样

–same-owner

尝试解压时保持所有者关系一致(超级用户默认此项)

-s, --preserve-order, --same-order

member arguments are listed in the same order as

the files in the archive

–sort=ORDER directory sorting order: none (default), name or

inode

Handling of extended file attributes:

–acls Enable the POSIX ACLs support

–no-acls Disable the POSIX ACLs support

–no-selinux Disable the SELinux context support

–no-xattrs Disable extended attributes support

–selinux Enable the SELinux context support

–xattrs Enable extended attributes support

–xattrs-exclude=MASK specify the exclude pattern for xattr keys

–xattrs-include=MASK specify the include pattern for xattr keys

设备选择和切换:

-f, --file=ARCHIVE 使用归档文件或 ARCHIVE 设备

–force-local

即使归档文件存在副本还是把它认为是本地归档

-F, --info-script=名称, --new-volume-script=名称

在每卷磁带最后运行脚本(隐含 -M)

-L, --tape-length=NUMBER 写入 NUMBER × 1024 字节后更换磁带

-M, --multi-volume 创建/列出/解压多卷归档文件

–rmt-command=COMMAND 使用指定的 rmt COMMAND 代替 rmt

–rsh-command=COMMAND 使用远程 COMMAND 代替 rsh

–volno-file=FILE 使用/更新 FILE 中的卷数

设备分块:

-b, --blocking-factor=BLOCKS 每个记录 BLOCKS x 512 字节

-B, --read-full-records 读取时重新分块(只对 4.2BSD 管道有效)

-i, --ignore-zeros 忽略归档中的零字节块(即文件结尾)

–record-size=NUMBER 每个记录的字节数 NUMBER,乘以 512

选择归档格式:

-H, --format=FORMAT 创建指定格式的归档

FORMAT 是以下格式中的一种:

gnu GNU tar 1. 格式

oldgnu GNU 格式 as per tar <= 1.12

pax POSIX 1003.1-2001 (pax) 格式

posix 等同于 pax

ustar POSIX 1003.1-1988 (ustar) 格式

v7 old V7 tar 格式

–old-archive, --portability

等同于 --format=v7

–pax-option=关键字[[:]=值][,关键字[[:]=值]]…

控制 pax 关键字

–posix 等同于 --format=posix

-V, --label=TEXT 创建带有卷名 TEXT

的归档;在列出/解压时,使用 TEXT

作为卷名的模式串

压缩选项:

-a, --auto-compress 使用归档后缀名来决定压缩程序

-I, --use-compress-program=PROG

通过 PROG 过滤(必须是能接受 -d

选项的程序)

-j, --bzip2 通过 bzip2 过滤归档

-J, --xz 通过 xz 过滤归档

–lzip 通过 lzip 过滤归档

–lzma 通过 xz 过滤归档

–lzop 通过 xz 过滤归档

–no-auto-compress 不使用归档后缀名来决定压缩程序

-z, --gzip, --gunzip, --ungzip 通过 gzip 过滤归档

-Z, --compress, --uncompress 通过 compress 过滤归档

本地文件选择:

–add-file=FILE 添加指定的 FILE 至归档(如果名字以 -

开始会很有用的)

–backup[=CONTROL] 在删除前备份,选择 CONTROL 版本

-C, --directory=DIR 改变至目录 DIR

–exclude=PATTERN 排除以 PATTERN 指定的文件

–exclude-backups 排除备份和锁文件

–exclude-caches 除标识文件本身外,排除包含

的目录中的内容

–exclude-caches-all 排除包含 的目录

–exclude-caches-under 排除包含

的目录中所有内容

–exclude-ignore=FILE read exclude patterns for each directory from

FILE, if it exists

–exclude-ignore-recursive=FILE

read exclude patterns for each directory and its

subdirectories from FILE, if it exists

–exclude-tag=FILE 除 FILE 自身外,排除包含 FILE

的目录中的内容

–exclude-tag-all=FILE 排除包含 FILE 的目录

–exclude-tag-under=FILE 排除包含 FILE 的目录中的所有内容

–exclude-vcs 排除版本控制系统目录

–exclude-vcs-ignores read exclude patterns from the VCS ignore files

-h, --dereference

跟踪符号链接;将它们所指向的文件归档并输出

–hard-dereference

跟踪硬链接;将它们所指向的文件归档并输出

-K, --starting-file=MEMBER-NAME

begin at member MEMBER-NAME when reading the

archive

–newer-mtime=DATE 当只有数据改变时比较数据和时间

–no-null 禁用上一次的效果 --null 选项
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

总结

我个人认为,如果你想靠着背面试题来获得心仪的offer,用癞蛤蟆想吃天鹅肉形容完全不过分。想必大家能感受到面试越来越难,想找到心仪的工作也是越来越难,高薪工作羡慕不来,却又对自己目前的薪资不太满意,工作几年甚至连一个应届生的薪资都比不上,终究是错付了,错付了自己没有去提升技术。

这些面试题分享给大家的目的,其实是希望大家通过大厂面试题分析自己的技术栈,给自己梳理一个更加明确的学习方向,当你准备好去面试大厂,你心里有底,大概知道面试官会问多广,多深,避免面试的时候一问三不知。

大家可以把Java基础,JVM,并发编程,MySQL,Redis,Spring,Spring cloud等等做一个知识总结以及延伸,再去进行操作,不然光记是学不会的,这里我也提供一些脑图分享给大家:

希望你看完这篇文章后,不要犹豫,抓紧学习,复习知识,准备在明年的金三银四拿到心仪的offer,加油,打工人!
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
这些面试题分享给大家的目的,其实是希望大家通过大厂面试题分析自己的技术栈,给自己梳理一个更加明确的学习方向,当你准备好去面试大厂,你心里有底,大概知道面试官会问多广,多深,避免面试的时候一问三不知。

大家可以把Java基础,JVM,并发编程,MySQL,Redis,Spring,Spring cloud等等做一个知识总结以及延伸,再去进行操作,不然光记是学不会的,这里我也提供一些脑图分享给大家:

[外链图片转存中…(img-nZ5UOpaV-1712646009174)]

[外链图片转存中…(img-BqzZMRLD-1712646009174)]

[外链图片转存中…(img-y5ERIrhJ-1712646009175)]

希望你看完这篇文章后,不要犹豫,抓紧学习,复习知识,准备在明年的金三银四拿到心仪的offer,加油,打工人!
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!