Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/linux/23.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Linux Bash:如何为ssh命令实时过滤tee输出?_Linux_Bash_Ssh_Tee - Fatal编程技术网

Linux Bash:如何为ssh命令实时过滤tee输出?

Linux Bash:如何为ssh命令实时过滤tee输出?,linux,bash,ssh,tee,Linux,Bash,Ssh,Tee,我的目标是为ssh会话中使用的命令创建一个带有时间戳的日志 只要输出未被过滤,Tee就会实时工作。当I tail-F test.log时,以下命令会实时追加输出: #!/bin/bash ssh "$@" | tee -a test.log 但是,当我尝试使用中建议的方法修改tee的输出时,输出不再是实时的。例如: #!/bin/bash ssh "$@" | tee >(grep -e '.*\@.*\:.*\$.*' --color=never >> test.log)

我的目标是为ssh会话中使用的命令创建一个带有时间戳的日志

只要输出未被过滤,Tee就会实时工作。当I tail-F test.log时,以下命令会实时追加输出:

#!/bin/bash
ssh "$@" | tee -a test.log
但是,当我尝试使用中建议的方法修改tee的输出时,输出不再是实时的。例如:

#!/bin/bash
ssh "$@" | tee >(grep -e '.*\@.*\:.*\$.*' --color=never >> test.log)
奇怪的是,如果我用“yes”命令代替ssh命令,那么输出会被实时正确过滤

实时处理很重要,因为我的脚本需要在每一行上附加一个当前时间戳,并尽可能多地删除输出。以下是我目前的脚本:

#!/bin/bash
logfile=~/test.log
desc="sshlog ${@}"
tab="\t"
format_line() {
    while IFS= read -r line; do
        echo "$(date +"%Y-%m-%d %H:%M:%S %z")${tab}${desc}${tab}${line}"
    done
}
echo "[START]" | format_line >> $logfile
ssh "$@" | tee >(grep -e '.*\@.*\:.*\$.*' --color=never | format_line >> $logfile)
echo "[END]" | format_line >> $logfile

我如何解决这个问题,为什么ssh命令在tee中的行为与yes命令不同?

问题很可能是
grep
正在缓冲其输出—选择大块输入,过滤它们,并输出结果—因此它可以平滑地处理
yes
的输出(因为
yes
会快速生成大量的输入以供过滤和输出),而
ssh
命令可能不会快速生成那么多的输出

许多版本的
grep
提供了一种调整缓冲的机制。由于您在Linux上,您可能会使用GNU grep,它为此提供了一个
--line buffered
标志(请参阅),因此每次只缓冲一行输出:

ssh "$@" | tee >(grep -e '.*\@.*\:.*\$.*' --color=never --line-buffered >> test.log)

如果您使用awk而不是grep,您将使用
fflush();
。这个问题是相关的:@ruakh我测试过您的tee输出重定向命令一般来说:'some command'| tee>('some filtering'>'output')它使用/bin/bash工作,但我在/bin/sh中使用它时出现语法错误,例如:syntax error:(“意外。有什么建议吗?感谢您的支持:)@GrayFox:进程替换(
>(…)
功能)这里实际上是一个问题——我在这里包括它是为了在上下文中显示
--行缓冲的
选项——所以我认为这个问题不适合问如何在不支持它的shell中近似处理替换。幸运的是,您不需要问:这个问题已经链接到,它有几个答案对基于非过程替代的方法进行改进。