本文介绍日志服务检索功能支持的检索语法。
注意
日志服务产品架构升级,支持更丰富的检索分析功能。
如何区分架构,请参考如何快速区分架构 1.0 和 2.0。关于架构的具体说明,请参考日志服务架构升级通知。
AND
、and
均表示检索逻辑运算符。AND
,OR
,&&
,!
等)必须使用半角括号(()
)明确逻辑操作优先级,否则搜索到的结果可能和预期不一致。例如搜索某台机器上 log
目录下不包含 error
的日志,可指定检索条件为 ((__source__:192.168.10.10 AND __path__:\/var\/log\/*) NOT error)
。AND
。例如 warning error
等同于 warning AND error
,表示检索内容中包含关键词 warning
和 error
的日志。操作符 | 说明 | 示例 |
---|---|---|
| 与逻辑操作符,表示取多个搜索结果的交集,指定多个逻辑操作时请使用半角括号()明确逻辑操作优先级。 |
|
| 或逻辑操作符,表示取多个搜索结果的并集。指定多个逻辑操作时请使用半角括号 |
|
| 非逻辑操作符,表示搜索结果不包含 NOT 之后的关键词。指定多个逻辑操作时请使用半角括号()明确逻辑操作优先级。 |
|
| 范围逻辑操作符,TO 前后应加空格。 |
|
| 单引号,单引号中的字符串包含预设的分词符时,被分词符拆分后的各个关键字之间为 AND 关系。 |
|
| 双引号,双引号中的字符串包含预设的分词符时,被分词符拆分后的各个关键字之间为 AND 关系。 |
|
| 冒号,表示键值检索,返回包含指定 Key 和 Value 的日志。 |
|
| 通配符,表示模糊查询。通配符 |
|
| 通配符,表示模糊查询。通配符 |
|
| 分组操作符,用于控制多个逻辑运算之间的优先级。 |
|
| 等号,表示在数值类型的字段中,查询 value 等于某个数值的日志。等号(=)和冒号(:)为相同作用。 |
|
| 范围操作符,表示在数值类型的字段中,查询 value 大于某个数值的日志。 |
|
| 范围操作符,表示在数值类型的字段中,查询 value 大于等于某个数值的日志。 |
|
| 范围操作符,表示在数值类型的字段中,查询 value 小于某个数值的日志。 |
|
| 范围操作符,表示在数值类型的字段中,查询 value 小于等于某个数值的日志。 |
|
| 范围操作符,范围中包含边界值。 |
|
| 范围操作符,范围中不包含边界值。 |
|
| 转义符。如果查询的关键词中包含保留字符,则需要通过转义符进行转义后再检索。转义后的字符代表字符本身,而不是不代表关键字。 |
|
预览字段 | 说明 | 示例 |
---|---|---|
| 筛选来源为指定 IP 地址的日志。支持通过通配符进行模糊查询。 |
|
| 筛选来源为指定路径下文件的日志。支持通过通配符进行模糊查询。 |
|
| 通过日志中的 time 字段进行筛选,支持范围查询。 |
|
说明
不同的索引配置,会有不同的检索结果。
场景 | 语句 |
---|---|
查询日志内容中包含 ERROR 的日志。 |
|
查询包含 level 字段的日志。 |
|
查询不包含 level 字段的日志。 |
|
查询来源为指定 IP 的某台机器或某些机器的日志。 |
|
查询日志采集路径为特定名字的某个文件或某些文件的日志。 |
|
查询状态码为 4xx 的访问日志。 |
|
查询状态码大于 400,即访问失败的日志。 |
|
在 GET 请求的访问日志中,查询请求失败的日志。 |
|
查询异常日志,即级别非 INFO 的日志。 |
|
查询 ERROR 或 WARNING 级别的日志。 |
|
查询指定机器上的异常日志,即来源为指定 IP 地址、级别非 INFO 的日志。 |
|
来源为指定 IP 地址、级别为 ERROR 或 WARNING 的日志。 |
|
查询指定机器上指定文件中的异常日志,即来源为指定 IP 地址、路径为指定文件、级别非 INFO 的日志。 |
|
通过预留字段 |
|
查询 Pod 名称为 application,且请求延时大于 3s 的日志。 |
|
查询包含字段名为 |
|
查询包含关键词 |
说明 not 默认为日志服务检索运算符,当 not 为普通的检索字符串时,需使用双引号("")包裹。 |
如果您在创建索引时开启了分词符功能,则日志服务会基于分词符,将日志内容拆分成多个关键词,您可以搜索各个关键词进行日志检索。日志服务支持的分词符包括 !@#%^&*"()-_=', <>/?|;:\n\t\r[]{}\.
。
例如 region
字段值为 cn-guilin
,并为该字段配置了键值索引。
当您未开启分词符时,cn-guilin
为一个整体,您使用guilin
检索语句将检索不到该日志。
当您设置分词符为!@#%^&*"()-_=', <>/?|;:\n\t\r[]{}\.
时,cn-guilin
将被拆分为 cn
、guilin
。您可以使用如下语句进行日志检索。
场景 | 检索语句 |
---|---|
查询 |
|
查询 |
|
查询包含以 |
|
使用短语查询可以精准匹配指定的短语,详细说明请参考短语查询。
场景 | 检索语句 |
---|---|
查询 |
|