BASH嵌套过程替换

时间:2015-04-07 04:39:46

标签: linux bash pipe named-pipes process-substitution

我正在尝试在while循环中使用进程替换的stdout,如下所示:

#!/bin/bash

FILE_1=f1.txt
FILE_2=f2.txt

while read LINE; do
    echo "$LINE"
done < <(paste <(tail -f "$FILE_1") <(tail -f "$FILE_2"))

每当新数据添加到文件时,它应该做的是合并FILE_1和FILE_2的最后几行。显然,我想做的不仅仅是在while循环中打印行,但这是一个很好的例子。

不幸的是,当我运行这个脚本时,它只是位于终端并且什么都不做。

只运行这一行:

paste <(tail -f "$FILE_1") <(tail -f "$FILE_2")

工作得很好,当我向文件中添加数据时,我可以在终端上看到输出。

为了将stdout传递给另一个进程,我需要使用一些特殊的语法吗?

我已经尝试过了

paste <(tail -f "$FILE_1") <(tail -f "$FILE_2") | while read LINE; do...

但它仍然只是在终端。

2 个答案:

答案 0 :(得分:5)

当stdout不是终端时,paste将缓冲其输出。你的命令有效,在发生任何事情之前只需要一定量的输入。

要立即获得输出,您可以使用stdbuf

取消缓冲标准输出
stdbuf -oL paste <(tail -f "$FILE_1") <(tail -f "$FILE_2") | while read LINE; do...

答案 1 :(得分:0)

我相信你有2个主要问题。首先,您需要结合使用此处字符串命令替换以及流程替换来完成您想要的重定向。例如:

while read LINE
do 
    echo "$LINE"
done <<< "$( paste <( tail -2 "$FILE_1" ) <( tail -2 "$FILE_1" ) )"

上面的命令工作正常。但是,注意上面的命令使用FILE_1FILE_2的一系列可确定的行,使用封闭形式的tail(例如tail -2 )。在这种情况下,我认为您不能使用follow选项。我正在寻找,但尚未找到原因。使用--serial选项进行粘贴没有任何区别。