加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Linux > 正文

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

发布时间:2020-12-13 19:52:32 所属栏目:Linux 来源:网络整理
导读:为什么读取-t在从RHEL5或RHEL6上的管道读取时没有超时? 这是我的示例,在我的RHEL框中没有超时从管道中读取: tail -f logfile.log | grep 'something' | read -t 3 variable 如果我读得正确-t 3应该在3秒后超时? 提前谢谢了. 克里斯 GNU bash,version 4.1.
为什么读取-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的退出状态.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读