为什么读取-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的退出状态.