3

我有一个从 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 分钟。

4

1 回答 1

3

我看到您已经找到了解决方法,所以我将尝试发现正在发生的事情:

bash不是将整个脚本读入内存,而是对其进行缓冲读取,每次只进行必要的读取(大概是为了与终端输入共享代码)。在启动任何外部命令之前,bash寻找脚本中的确切位置并在命令完成后继续从那里读取。如果您在运行时编辑脚本文件,您可以看到它:

term1$ cat > test.sh
sleep 8
echo DONE
term1$ bash test.sh

sleep执行时,从另一个终端更改脚本:

term2$ cat > test.sh
echo HAHA

观察完成后如何bash变得混乱sleep

test.sh: line 2: A: command not found

它记得输入文件中的位置是 8 之前的位置sleep,因此它尝试从那里读取并遇到A被覆盖脚本的最后一个位置。

现在谈谈你的情况。通常,从 dvd 打开文件会锁定驱动器并禁止更改磁盘。如果您仍然设法更改磁盘,那肯定会涉及一个 umount,这应该会使脚本 fd 无效。根据您的strace输出,这显然没有发生,这有点奇怪。无论如何,bash将无法阅读脚本的其余部分。

于 2013-06-14T13:59:59.260 回答