微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

有没有办法在不中断输出的情况下从pipe道尾部命令每分钟打印一次?

我有一个长长的pipe道尾部命令,我通过ssh执行(例如tail -f <file>|egrep -v "lol" ),通常没有太多的输出,并且要确保连接是静止的喜欢每60或300秒打印一次。

CodeDeploy PM2命令未find

Shell代码在控制台中工作,但不在脚本中

自动将所有环境variables从一个shell转移到另一个shell

自动化input键盘不能用于Linux Mint 15

获取在Linux中打开的应用程序窗口的数量

你应该能够转换命令的顺序,并得到你的tail -f输出的date :

( while : ; do date; sleep 60; done )& tail -f <file>|egrep -v "lol"; kill %1

注意:您正在为每60秒提供一次日期的过程进行后台处理,因此您需要在完成kill %1时终止后台作业。 如果您有多个进程的后台,则需要捕获作业编号。 我已经尝试过系统日志,它似乎工作。 如果在你的情况下工作,请回报。

尝试:

tail -f file | perl -ne 'BEGIN{$|=1} print unless /lol/'

当然,如果你只是想打印一个时间戳,请尝试:

tail -f file | { while sleep 60; do date; done& grep -v lol; }

在管道的末尾添加一个这样的脚本:

#!/bin/bash while : ; do # Read input with timeout read -t 10 line # Output if we got anything and remember current time in "last" [[ $? -eq 0 ]] && last=$(date +%s) && echo $line # Check if we are due a timestamp and output if required Now=$(date +%s) diff=$((Now-last)) [[ $diff -ge 60 ]] && last=$(date +%s) && date done

它从stdin读取10秒的超时。 如果数据不断出现,它不断打印。 每次执行一些输出时,都会使用最后一次输出的时间更新变量。 然后每次检查是否有最后60个输出,如果没有输出,则输出当前时间。

将上述内容保存在一个名为monitor的文件中,然后将其设置为可执行文件(仅限一次),然后像这样运行:

chmod +x monitor yourpipe ...| ... | ./monitor

它可以被缩写成一些清晰的代价,像这样。 此外, date的执行可以通过使用内置的bash SECONDS来避免:

#!/bin/bash last=$SECONDS while : ; do read -t 10 line && [[ $? -eq 0 ]] && last=$SECONDS && echo $line [[ $(($SECONDS-last)) -ge 60 ]] && last=$SECONDS && date done

或者,稍微不同的方法…做一个FIFO,并发送你的原始管道的输出,尾巴,但在后台,有一个小循环,也发送时间戳到FIFO每分钟一次。 像这样(未经测试)

mkfifo FIFO original_pipe | ... | ... > FIFO &

现在每隔60秒向FIFO中注入一个时间戳:

while :; do date > FIFO; sleep 60; done &

现在只需尾部FIFO

tail -F FIFO

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐