我目前拥有的:
kubectl logs --timestamps jenkins-68bb89fd4d-fdnwj | sed "/2020-05-15/ q"
2020-05-15T21:48:34.356315314Z Running from: /usr/share/jenkins/jenkins.war
它有什么作用:
它读取带有时间戳的日志,并在 sed 找到匹配项后停止。在这种情况下,我只想提取给定时间范围内的日志,例如2020年5月17日至2020年5月19日。 Kubectl 提供标志 --since-time= 允许指定日志的开始日期,但是没有 --until-time 标志或等效标志。我当前方法的问题是,假设我正在查找的模式将出现在日志中,但情况可能并非如此。在这种特定情况下,给定的一天可能没有日志,但之后的一天会有日志。
我在寻找什么:
如果我只要模式匹配就读取流,我就可以实现我的目标。在这种情况下,我可以在 bash 中包含日期列表,例如
dates = (2020-05-15 2020-05-16 2020-05-17)
但是我不知道是否可以为 sed 指定模式,因此一旦模式停止匹配它就会退出。用sed可以实现吗?如果没有,可以使用 awk、grep 或其他工具来实现吗?
最佳答案
命令
awk '/pattern/ { print; next } { exit }'
打印与模式匹配的行,遇到不包含模式匹配的行时退出。 /pattern/
语法可以替换为多个字段等的复杂表达式。
/pattern/ { print; next }
表示:“如果pattern
匹配,则打印该记录,然后完成该记录的处理;转到下一条记录。”
{ exit }
是一个无条件操作,因为它前面没有模式表达式。 exit
是 Awk 中的内置语句;如果省略其参数,则终止状态成功。
关于bash - 只要模式匹配就读取流,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63305389/