linux 过滤非输出信息,linux – Bash:如何为ssh命令实时过滤tee输出?

博主遇到的问题是在SSH会话中使用带有时间戳的日志记录,并通过grep进行实时过滤时,输出不再实时。当使用`yes`命令替换`ssh`时,输出能够正常实时过滤。目前的脚本在过滤SSH输出时遇到延迟,导致无法实现实时日志。博主寻求解决方案,以确保在处理SSH命令输出时保持日志记录的实时性。
摘要由CSDN通过智能技术生成

我的目标是为我的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命令?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值