linux – 为什么`读-t`没有在RHEL上的bash中超时?

前端之家收集整理的这篇文章主要介绍了linux – 为什么`读-t`没有在RHEL上的bash中超时?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
为什么读取-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的退出状态.

猜你在找的Linux相关文章