tar命令仅打包不压缩,压缩需显式指定-z(gzip)、-j(bzip2)或-j(xz)参数;-f必须紧接归档文件名,顺序错误或路径不当会导致报错;解压须匹配压缩类型,排除无用文件可大幅减小体积。

tar 命令不压缩,只是打包 —— 默认根本没调用 gzip/bzip2/xz
很多人执行 tar -cf archive.tar dir/ 后发现文件体积几乎没变,就以为“压缩失败”。其实这是正常现象:tar 本身只负责归档(把多个文件捆成一个),不带压缩逻辑。压缩必须显式加参数触发对应压缩程序。
-
-z:调用gzip(最常用,兼容性好,速度中等) -
-j:调用bzip2(压缩率高,但慢,部分旧系统默认没装) -
-J:调用xz(压缩率最高,内存占用大,解压时需注意xz是否可用) - 漏掉这些字母,
tar就只打包,不压缩
常见错误:-z 和 -f 顺序写反导致“Cannot open: No such file or directory”
错误命令如 tar -zcf archive.tar.gz -f dir/,这里 -f 后面跟了 dir/,tar 就会误以为归档名是 dir/,而实际要打包的目录没指定,最终报错找不到归档文件。
-
-f必须紧接归档文件名,且只能出现一次 - 正确写法是
tar -zcf archive.tar.gz dir/(-f隐含在archive.tar.gz里) - 也可以显式写成
tar -zcf -f archive.tar.gz dir/,但-f一定要在归档名前面,且归档名不能是目录或不存在路径 - 如果归档名含空格,务必用引号包裹:
tar -zcf "my archive.tar.gz" dir/
解压时选错参数,tar 直接报 “Unknown file type” 或跳过内容
比如用 tar -xvf archive.tar.gz 解一个其实是 xz 压缩的 .tar.xz 文件,tar 会尝试用默认方式读取,大概率解出空目录或报错 tar: Skipping to next header。
- 先用
file archive.tar.xz看真实压缩类型,别光看后缀 -
.tar.gz/.tgz→ 用-z:tar -xzf archive.tar.gz -
.tar.bz2→ 用-j:tar -xjf archive.tar.bz2 -
.tar.xz→ 用-J:tar -xJf archive.tar.xz - 不确定时,可以加
--help快速查当前 tar 支持哪些压缩后端(有些精简版系统缺xz支持)
打包时忽略 .git / node_modules 会导致归档巨大且无意义
直接 tar -zcf project.tar.gz . 会把整个工作目录原样打进包,包括 Git 历史、依赖模块、日志、临时文件 —— 不仅体积膨胀数倍,还可能泄露敏感信息。
- 用
--exclude排除目录:tar -zcf project.tar.gz --exclude='.git' --exclude='node_modules' --exclude='*.log' . - 更稳妥的方式是写
.tarignore(非标准,但可用--files-from 模拟) - 注意
--exclude的路径匹配基于打包时的相对路径,不是绝对路径;如果从子目录运行,排除规则要相应调整 - 想验证排除是否生效?加
-t先列文件:tar -tzf project.tar.gz | head -20
tar 的压缩能力完全依赖外部工具是否就位、参数是否匹配、排除逻辑是否写对路径——尤其当脚本自动化打包时,这些细节一错,生成的包要么打不开,要么大得离谱。










