3

我正在尝试在 GCP 中创建一个基于日志的指标,以用于警报规则(StackDriver,现在是 GCP 的一部分)。来源是 HTTPS (L7) LB 日志。经过大量试验和错误后,我发现如果我使用基于正则表达式的过滤器,我的指标不起作用(注意:基于正则表达式的标签提取工作,在下面描述的更改之后)。

具体来说,如果我的过滤器看起来像这样:

httpRequest.status=403
httpRequest.requestMethod="GET"
httpRequest.requestUrl=~"^.*some/regex/pattern/.*$"

单击“提交过滤器”后,我确实看到了过滤的日志条目,当我设置基于正则表达式的标签提取器时,我还看到了示例记录/标签,但在指标资源管理器中,时间序列中没有任何数据。但是,如果我更改过滤器以进行纯全文子字符串匹配,即

httpRequest.status=403
httpRequest.requestMethod="GET"
"some/substring/match"

它确实有效 - 我确实在指标资源管理器中看到了时间序列。

请注意,这不是时间问题,我还不够耐心。通过在两个过滤器之间切换,我可以可靠地使其工作(或不工作)。

这对我来说是个问题,因为我确实需要请求 URL 上的正则表达式匹配;子字符串匹配不够复杂,此外,我想确保只匹配请求 URL,而不是引用者。虽然我基本上可以使用更粗略的过滤器(即使这会破坏指标),但这会导致我的警报规则出现另一个问题,因为我无法过滤掉不匹配项——提取的标签没有值,甚至label !=~ [[:space:]]*没有无法在警报级别过滤掉不匹配项,因为缺少标签值显然与空标签值不同。由于过于粗略的日志过滤器而导致的 FP 警报我来说是个大问题。

如果这是预期的行为,我会感谢突出显示此限制的文档的链接。

4

1 回答 1

0

正如之前的评论所指出的,由于在查询中使用了正则表达式,因此存在与无效查询语法相关的问题。

日志查看器不支持特殊通配符,如*?

您可以在文档中找到更多无效搜索示例。

于 2022-01-24T11:59:50.880 回答