只要模式匹配就读取流
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 语句;如果省略其参数,则终止状态为成功。
我目前拥有的:
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 语句;如果省略其参数,则终止状态为成功。