linux – Bash:如何为ssh命令实时过滤tee输出?
发布时间:2020-12-14 01:28:28 所属栏目:Linux 来源:网络整理
导读:我的目标是为我的ssh会话中使用的命令创建一个带时间戳的日志. 只要输出未被过滤,Tee就可以实时工作.当我tail -F test.log时,以下命令实时附加输出: #!/bin/bashssh "$@" | tee -a test.log 但是,当我尝试通过this question中建议的方法修改tee的输出时,输
我的目标是为我的ssh会话中使用的命令创建一个带时间戳的日志.
只要输出未被过滤,Tee就可以实时工作.当我tail -F test.log时,以下命令实时附加输出: #!/bin/bash ssh "$@" | tee -a test.log 但是,当我尝试通过this question中建议的方法修改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的输出(因为是的,它会快速生成大量输入以进行过滤和输出),而你的ssh命令可能不会产生尽可能快的输出.
许多版本的grep提供了一种调整缓冲的机制.由于您使用的是Linux,因此您可能使用GNU Grep,它为此提供了一个–line-buffered标志(参见the “Other Options” section of the GNU Grep Manual),因此输出一次只缓冲一行: ssh "$@" | tee >(grep -e '.*@.*:.*$.*' --color=never --line-buffered >> test.log) (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |