我正在尝试实现一个等待日志文件中的特定消息的脚本.记录消息后,我想继续脚本.
这是我用tail -f和grep -q尝试的东西:
# tail -f logfile | grep -q 'Message to continue'
grep永远不会退出,所以即使文件中记录了“要继续的消息”,它也会永远等待.
当我没有-f运行它似乎工作正常.
解决方法
tail -f将读取文件并显示稍后添加的行,它将不会终止(除非发送SIGTERM之类的信号). grep不是这里的阻塞部分,tail -f是. grep将从管道中读取,直到它被关闭,但它绝不是因为tail -f没有退出并保持管道打开.
您的问题的解决方案可能是(未经过测试且很可能表现不佳):
tail -f logfile | while read line; do echo $line | grep -q 'find me to quit' && break; done