分页: 1 / 1
[已解决]为何tee重定向到':'(空命令)就不写文件?
发表于 : 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
Re: 为何tee重定向到':'(空命令)就不写文件?
发表于 : 2017-09-04 12:10
由 vickycq
发现只要管道符号的右侧是 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
Re: 为何tee重定向到':'(空命令)就不写文件?
发表于 : 2017-09-04 20:29
由 vickycq
@astolia 高手来看看啊
Re: 为何tee重定向到':'(空命令)就不写文件?
发表于 : 2017-09-04 21:01
由 astolia
@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 | :'