【发布时间】:2013-06-14 11:15:00
【问题描述】:
我有一个从 DVD 运行的 bash 脚本。此脚本将多卷 tar 文件从 DVD 复制到本地计算机。在复制过程中,脚本提示用户插入第二张 DVD,此时剩余的文件将被复制。该脚本存在于第一张 DVD 上,但不存在于第二张 DVD 上。
此脚本只是在复制最后一个文件后停止,但在开始 tar 多卷提取操作和后续处理之前。没有报告错误或消息。我试过用'-x'运行bash,但没有什么可疑的——甚至没有退出语句。更不幸的是,这种行为是不一致的。有时脚本会停止,但有时会继续运行而没有问题。
我已经在脚本上运行了 strace。复制操作结束后,我看到:
read(255, "\0\0\0\0\0\0\0\0\0\0"..., 5007) = 1302
read(255, "", 5007) = 0
exit_group(0) = ?
我知道 bash 将脚本文件读入内存并从那里执行,但它是否有可能在某个时候尝试重新读取脚本文件并失败(因为它不再存在)? tar 文件非常大,从脚本启动到最后一个文件被复制(从第二张 DVD)大约需要 10-15 分钟。
【问题讨论】:
-
dmesg 中是否有任何内容表明您内存不足或类似情况?我倾向于尝试修改脚本以将自身复制到本地存储,并从那里执行自身。
-
感谢您的建议。我会检查dmesg。我实际上曾考虑将脚本复制到 /tmp 然后从那里重新调用它。我唯一担心的是父脚本仍然是从 DVD 执行的。据推测,bash 不会尝试重新读取父脚本,直到子脚本退出(此时我已经完成了)。
-
我只是能够重现它。 dmesg 中没有任何内容。有趣的是,我在运行“cat /dev/zero > /dev/shm/file”并在 vi 中打开一个非常大的日志文件以尽可能多地使用内存时复制了它(我的内存减少到 32M!) .我不确定是这些原因造成的,还是我只是幸运,但值得注意。我将修改脚本以将其自身复制到 /tmp,然后从那里重新运行它。然后,我会重新测试。我们会看看会发生什么。
标签: linux bash shell tar strace