为什么读取-t在从RHEL5或RHEL6上的管道读取时没有超时?
这是我的示例,在我的RHEL框中没有超时从管道中读取:
tail -f logfile.log | grep 'something' | read -t 3 variable
如果我读得正确-t 3应该在3秒后超时?
提前谢谢了.
克里斯
GNU bash,version 4.1.2(1)-release (x86_64-redhat-linux-gnu)
解决方法
虽然不能直接回答您的具体问题,但您需要运行类似的问题
read -t 3 variable < <( tail -f logfile.log | grep "something" )
为了在管道完成后可以看到新设置的变量值.看看这是否按预期超时.
由于您只是在一段固定的时间后使用read作为退出管道的方法,因此您不必担心变量的范围.但是,由于内部缓冲,grep可能会在超时内找不到匹配项.您可以使用–line-buffered选项禁用它(至少使用GNU grep):
tail -f logfile.log | grep --line-buffered "something" | read -t 3
另一个选项(如果可用)是timeout命令作为read的替代:
timeout 3 tail -f logfile.log | grep -q --line-buffered "something"
在这里,我们在3秒后杀死尾部,并以通常的方式使用grep的退出状态.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。