linux – 为什么`读-t`没有在RHEL上的bash中超时?
发布时间:2020-12-30 13:04:43 所属栏目:Linux 来源:互联网
导读:为什么读取-t在从RHEL5或RHEL6上的管道读取时没有超时? 这是我的示例,在我的RHEL框中没有超时从管道中读取: tail -f logfile.log | grep something | read -t 3 variable 如果我读得正确-t 3应该在3秒后超时? 提前谢谢了. 克里斯 GNU bash, version 4.1.2(
|
为什么读取-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 – 我的引导程序无法使用gcc 4.6和4.7 …只编译4.5
- 为什么`ping`在Linux中没有超时?
- linux – kswapd在使用交换时经常使用100%的CPU
- LINUX教程:OpenLDAP安装及设置普通用户修改自己密码
- centos7.3 yum 安装php7.1
- LINUX学习:Linux审计服务Auditd systemctl重启问题解决
- 如何在Linux Ubuntu 16上安装luasql?
- webserver – Angstrom Linux上的Web服务器根目录(BeagleBo
- linux内核 – remap_pfn_range如何将内核内存重新映射到用户
- gedit插件错误 – 找不到插件加载器’python3′
