- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我需要使用像 xz 这样的压缩器来压缩巨大的 tar 文件。
我完全了解之前的问题,例如 Create a tar.xz in one command和 Utilizing multi core for tar+gzip/bzip compression/decompression
从他们那里,我发现这个命令行大部分有效:
tar -cvf - paths_to_archive | xz -1 -T0 -v > OUTPUT_FILE.tar.xz
我使用管道解决方案,因为我绝对必须能够将选项传递给 xz。特别是,xz 非常占用 CPU 资源,因此我必须使用 -T0 来使用所有可用内核。这就是为什么我不使用其他可能性,例如 tar 的 --use-compress-program 或 -J 选项。
不幸的是,我真的想将 tar 和 xz 的所有日志输出(即非存档输出)捕获到日志文件中。在上面的示例中,注销始终由这些 -v
选项生成。
使用上面的命令行,该日志输出现在打印在我的终端上。
所以,问题是当你像上面那样使用管道连接 tar 和 xz 时,你不能用类似的东西结束命令行
>Log_File 2>&1
因为之前
> OUTPUT_FILE.tar.xz
有解决办法吗?
我尝试包装在这样的子外壳中
(tar -cvf - paths_to_archive | xz -1 -T0 -v > OUTPUT_FILE.tar.xz) >Log_File 2>&1
但这没有用。
最佳答案
tar
的正常 stdout 是 tarball,xz
的正常 stdout 是压缩文件。这些都不是您应该捕获的日志。 除输出文件本身之外的所有日志记录都专门写入两个进程的 stderr。
因此,您只需要重定向 stderr,并且不能重定向 stdout,除非您希望输出文件与日志记录混合在一起。
{ tar -cvf - paths_to_archive | xz -1 -T0 -v > OUTPUT_FILE.tar.xz; } 2>Log_File
<小时/>
顺便说一句 - 如果您好奇为什么 xz -v
在输出到 TTY 时会打印更多内容,答案是 in this line of message.c
:只有当 isatty(STDERR_FILENO)
为 true 时,才会设置 progress_automatic
标志(告诉 xz 设置一个计时器来触发 SIGALRM
——它将其视为应该每秒打印一次状态的指示)。因此,在 stderr 被重定向到文件后,xz 根本不再打印此输出;问题不在于它没有正确重定向,而在于它不再存在。
但是,如果您真的愿意的话,您可以每秒从您自己的代码发送 SIGALRM
到 xz
:
{
xz -1 -T0 -v > OUTPUT_FILE.tar.xz < <(tar -cvf - paths_to_archive) & xz_pid=$!
while sleep 1; do
kill -ALRM "$xz_pid" || break
done
wait "$xz_pid"
} 2>Log_File
(避免将 xz
执行所需时间四舍五入到最接近的秒的代码是可能的,但留给读者作为练习)。
关于linux - 如何在执行 tar 时重定向 xz 的正常 stdout | xz?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48452726/
我正在使用 tf 函数列出 tar.gz 文件的内容。它非常大~1 GB。大约有 1000 个文件以年/月/日文件结构组织。 列表操作需要一些时间。似乎列表应该很快。谁能告诉我内部原理? 谢谢- 最佳
如何将信息通过管道传输到 tar 中并指定文件名? 最佳答案 类似于: tar cfz foo.tgz --files-from=- 但请记住,这不适用于所有可能的文件名;您应该考虑使用 --null
我总是用 tar czf file.tar.gz dirname而不是 tar -czf file.tar.gz dirname (没有 - )因为更快 我知道......从文档中,我所做的是错误的。
我有一个小型的 bash 单行代码,可以从各种来源下载存档列表。以下是包含该列表的文件示例: http://this-is-url1/url1.tar.gz http://www.this-is-ur
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
假设我在服务器 A 上使用 tar -czvf subdir.tgz subdirectory/* 创建了一个 tar 存档。 .如果我在服务器 B 上有一个并行结构,我已将此 tarball 复制到
我看到Linux tar有一个选项--overwrite。但是覆盖似乎是默认设置。而且,指定tar --no-overwrite不会更改此行为,因为信息文件似乎暗示了这一点。 那么,该选项实际上是做什
我需要创建一个任意大的 tarfile 用于测试,但不希望它写入磁盘。 最简单的方法是什么? 最佳答案 您可以轻松地使用 python 生成这样的 tarfile: mktar.py: #!/usr/
[root@c0002242 lfeng]# tar -zxvf/opt/test/ALLscripts.tar.gz -C/opt/test1 tar:这看起来不像 tar 存档 tar:跳到下一个
tar -xvzf $文件名.tar.gz || { 退出 $?; } 这里我的脚本将退出并显示错误代码 141。我使用的是 Fedora Core 6 和 tar 版本 1.15 这种情况不会一直发
我无法运行 docker-compose up 或 docker-compose build --no-cache。两者都以 ERROR: Error processing tar file(arch
我对 linux 平台非常陌生,我想为 ubuntu 提取 gnutls。如果我做, $ls 然后,它将在下面显示这些文件。 gnutls-3.2.1.tar.lz gnutls-3.2.1.tar.
我有一个巨大的 tarbell 存档,其中包含过大或损坏的 error_log,导致存档在尝试解压缩时挂起。有没有办法在解压缩或提取存档之前从存档中删除它,而无需在 Mac OS X 终端上提取该特定
我正在尝试针对特定用例评估 Artifactory,并且正在寻找可以支持将 Artifactory 用于文件存储库的文档。 我找到的只是一个用于部署 Artifactory 的文档,这些文档已存档在
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我想写一个有两个参数的脚本1. 父目录名称(例如 mainFolder)2.要创建的tar名称 父目录将包含子文件夹(文件夹 1、文件夹 2、文件夹 3 等)。我需要一个脚本来创建“mainFolde
假设我在 /tmp 中。我想压缩 /tmp/aaa/123,/tmp/bbb/222。我使用的命令是:tar -vczf/tmp/my.tar.gz/tmp/aaa/123/tmp/bbb/222。这
我有一个bzip2ed tar 文件和一个包含文件列表的文本文件。我想从 tar 中提取文本文件中列出的文件,将它们添加到一个新的 tar 中,然后从第一个 tar 中删除它们。 例如,如果我有这样一
本文实例讲述了Python打包文件夹的方法。分享给大家供大家参考,具体如下: 1、zip ?
我输入这个命令su -c busybox tar -xvf/storage/emulated/0/Download/andrax.r5-build5.tar.xz -C/data/data/com.t
我是一名优秀的程序员,十分优秀!