我根据How can I split and re-join STDOUT from multiple processes?提出了以下问题。
以下Bash命令将command1
的输出分成两个流,分别进入command2
和command3
,然后将它们的输出组合并通过管道传递到command4
中。
((command1 | tee >(command2 >&3) | command3) 3>&1) | command4
以图形方式显示如下:
command2
/ \
command1 command4
\ /
command3
我将如何在Sh shell中执行此操作?
答案 0 :(得分:2)
使用带有后台进程的fifo代替进程替换。
fifo=$(mktemp -u)
mkfifo "$fifo"
{
command2 <"$fifo" &
command1 | tee "$fifo" | command3
wait
} | command4
示例在docker上的高山linux上的busybox上进行了测试:
f() { sed 's/^/'"$1"' /'; } ;
fifo=$(mktemp -u); mkfifo "$fifo";
{ f 2 <"$fifo" & seq 3 | tee "$fifo" | f 3; wait; } | f 4;
rm "$fifo";
将输出:
4 3 1
4 3 2
4 3 3
4 2 1
4 2 2
4 2 3