只要模式匹配就读取流

Read stream as long as pattern matches

我目前拥有的:

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-05-17 - 2020-05-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 中的 built-in 语句;如果省略其参数,则终止状态为成功。