Ole*_*leg 4 linux ssh bash tee
我的目标是为我的ssh会话中使用的命令创建一个带时间戳的日志.
只要输出未被过滤,Tee就可以实时工作.当我tail -F test.log时,以下命令实时附加输出:
#!/bin/bash
ssh "$@" | tee -a test.log
Run Code Online (Sandbox Code Playgroud)
但是,当我尝试通过此问题中建议的方法修改tee的输出时,输出不再是实时的.例如:
#!/bin/bash
ssh "$@" | tee >(grep -e '.*\@.*\:.*\$.*' --color=never >> test.log)
Run Code Online (Sandbox Code Playgroud)
奇怪的是,如果我用"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
Run Code Online (Sandbox Code Playgroud)
我该如何解决这个问题,为什么ssh命令与tee的行为不同于yes命令?
rua*_*akh 11
问题很可能grep是缓冲其输出 - 选择大块输入,过滤它们并输出结果 - 因此它可以yes平滑地处理输出(因为yes它可以快速生成大量输入以进行过滤和输出),而ssh命令可能不会快速生成那么多输出.
许多版本都grep提供了一种机制来调整这种缓冲.由于你使用的是Linux,你可能会使用GNU Grep,它--line-buffered为此提供了一个标志(请参阅GNU Grep手册的"其他选项"部分),以便输出一次只缓冲一行:
ssh "$@" | tee >(grep -e '.*\@.*\:.*\$.*' --color=never --line-buffered >> test.log)
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3291 次 |
| 最近记录: |