[已解决]为何tee重定向到':'(空命令)就不写文件?

sh/bash/dash/ksh/zsh等Shell脚本
回复
科学之子
帖子: 2229
注册时间: 2013-05-26 6:58
系统: Debian 9
送出感谢: 833 次
接收感谢: 30 次

[已解决]为何tee重定向到':'(空命令)就不写文件?

#1

帖子 科学之子 » 2017-09-04 11:06

为何tee重定向到':'(空命令)就不写文件?
bash和dash都这样

代码: 全选

#不写文件
>./tx ; echo 2 | tee ./tx | : ; cat ./tx

代码: 全选

#重定向到cat就会正常写文件
$ >./tx ; echo 2 | tee ./tx | cat ; cat ./tx
2
2
上次由 科学之子 在 2017-09-04 21:45,总共编辑 1 次。
头像
vickycq
论坛版主
帖子: 4552
注册时间: 2011-03-20 13:12
系统: Debian
来自: 山东省寿光县
送出感谢: 100 次
接收感谢: 994 次
联系:

Re: 为何tee重定向到':'(空命令)就不写文件?

#2

帖子 vickycq » 2017-09-04 12:10

发现只要管道符号的右侧是 bash builtin 命令就有一定机率出现这个情况

echo 2 | tee tx | true
这个 100% 失败

echo 2 | tee tx | /bin/true
这个成功率比较高 有个别失败的

echo 2 | tee tx | alias
这个测试了 100 次,42 次成功 (我的 alias 比较多)
换成 bash --norc,没有任何 alias,测试了 100 次没有一次成功的

胡乱瞎猜:可能是右边返回太快的缘故。导致左边收到 SIGPIPE
这些用户感谢了作者 vickycq 于这个帖子:
科学之子 (2017-09-04 12:22)
评价: 3.7%
Debian 中文论坛 - forums.debiancn.org
欢迎所有 Debian GNU/Linux 用户
头像
vickycq
论坛版主
帖子: 4552
注册时间: 2011-03-20 13:12
系统: Debian
来自: 山东省寿光县
送出感谢: 100 次
接收感谢: 994 次
联系:

Re: 为何tee重定向到':'(空命令)就不写文件?

#3

帖子 vickycq » 2017-09-04 20:29

@astolia 高手来看看啊 :-)
Debian 中文论坛 - forums.debiancn.org
欢迎所有 Debian GNU/Linux 用户
头像
astolia
论坛版主
帖子: 3033
注册时间: 2008-09-18 13:11
送出感谢: 1 次
接收感谢: 500 次

Re: 为何tee重定向到':'(空命令)就不写文件?

#4

帖子 astolia » 2017-09-04 21:01

@vickycq 你 @ 我干什么,就是你猜的那样啊,|之后的结束的太快,管道崩坏,tee的实现又是先写stdout再写指定文件,结果写stdout时收到SIGPIPE信号没处理就挂了。

代码: 全选

$ wget --quiet https://ftp.gnu.org/gnu/coreutils/coreutils-8.28.tar.xz -O- | tar -xJO coreutils-8.28/src/tee.c | sed -n '237,238p'
      /* Write to all NFILES + 1 descriptors.
         Standard output is the first one.  */
用strace和ltrace看一下相关进程的执行时序会更清楚些

代码: 全选

strace -f bash -c 'echo 2 | /usr/bin/tee ./tx | :'
ltrace -f bash -c 'echo 2 | /usr/bin/tee ./tx | :'
这些用户感谢了作者 astolia 于这个帖子 (主题 2):
科学之子 (2017-09-04 21:11) • vickycq (2017-09-04 21:25)
评价: 7.41%
回复

回到 “Shell脚本”