分隔符格式

最近更新时间:2019-06-05 20:10:33

概述

分隔符日志是指一条日志数据可以根据指定的分隔符将整条日志进行结构化处理,每条完整的日志以换行符\n为结束标识符。日志服务在进行分隔符格式日志处理时,您需要为每个分开的字段定义唯一的 key。

示例

假设您的一条日志原始数据为:

10.20.20.10 - ::: [Tue Jan 22 14:49:45 CST 2019 +0800] ::: GET /online/sample HTTP/1.1 ::: 127.0.0.1 ::: 200 ::: 647 ::: 35 ::: http://127.0.0.1/

当日志解析的分隔符指定为:::,该条日志会被分割成八个字段,并为这八个字段定义唯一的 key,如下所示:

IP: 10.20.20.10 -
bytes: 35
host: 127.0.0.1
length: 647
referer: http://127.0.0.1/
request: GET /online/sample HTTP/1.1
status: 200
time: [Tue Jan 22 14:49:45 CST 2019 +0800]

采集配置

1. 登录控制台

登录 日志服务控制台,左侧选择日志集管理。

2. 新建 LogListener 采集

选择目标日志集,单击【新建日志主题】,输入日志主题名称:test-separator ,单击【确定】。

3. 配置 LogListener 采集

单击 LogListener 采集的日志主题,在采集配置界面中单击右上角【编辑】按钮,进入到编辑模式,开启【采集状态】和【使用 LogListener】。

4.配置日志文件采集路径

日志采集路径格式为 [目录前缀表达式]/**/[文件名表达式] ,LogListener 会按照 [目录前缀表达式] 匹配所有符合规则的公共前缀路径,并监听这些目录(包含子层目录)下所有符合 [文件名表达式] 规则的日志文件,参数详细说明如下:

字段 说明
目录前缀 日志文件前缀目录结构,仅支持通配符 * 和 ? ,* 表示匹配多个任意字符,? 表示匹配单个任意字符
/**/ 表示当前目录以及所有子目录
文件名 日志文件名,仅支持通配符 * 和 ? ,* 表示匹配多个任意字符,? 表示匹配单个任意字符

常用配置模式参考:
[公共目录前缀]/**/[公共文件名前缀]*
[公共目录前缀]/**/*[公共文件名后缀]
[公共目录前缀]/**/[公共文件名前缀]*[公共文件名后缀]
[公共目录前缀]/**/*[公共字符串]*

填写示例:

序号 目录前缀表达式 文件名表达式 说明
1. /var/log/nginx access.log 此例中,日志路径配置为 /var/log/nginx/**/access.log, LogListener 将会监听 /var/log/nginx 前缀路径下所有子目录中以 access.log 命名的日志文件
2. /var/log/nginx *.log 此例中,日志路径配置为 /var/log/nginx/**/*.log,LogListener 将会监听 /var/log/nginx 前缀路径下所有子目录中以 .log 结尾的日志文件
3. /var/log/nginx error* 此例中,日志路径配置为 /var/log/nginx/**/error*,LogListener 将会监听 /var/log/nginx 前缀路径下所有子目录中以 error 开头命名的日志文件

注意:

  1. 多层目录和通配符配置方式依赖2.2.2及以上版本的 loglistener,为兼容低版本 loglistener 路径配置修改方式,用户可切换旧配置进行历史修改,旧采集路径方式不支持多目录采集。
  2. 一个日志文件只能被一个日志主题采集。
  3. LogListener 不支持监听软连接方式的日志文件和监听 NFS、CIFS 等共享文件目录上的日志文件。

5. 关联机器组

从机器组列表中选择目标机器组,将其与当前日志主题进行关联,值得注意的是,关联的机器组与日志主题所在的地域需保持一致。操作详情请参阅 如何创建机器组 文档。

6. 分隔符模式选择

【键值提取模式】请选择分隔符,如下图所示:

7. 确定分隔符

首先需要您选择唯一的分隔符,系统根据确定的分隔符将日志样例进行切分,并展示在抽取结果栏中,您需要为每个字段定义唯一的 key。目前,日志采集支持多种分隔符,常见的分隔符有:空格、制表符、逗号、分号、竖线,若您的日志数据所采用的分隔符是其他符号,例如 ::: ,也可以通过自定义分词符进行解析。

8. 采集时间配置

  • 日志时间单位为:秒。
  • 日志的时间属性有两种方式来定义:采集时间和原始时间戳。
  • 采集时间:日志的时间属性由日志服务 CLS 采集该条日志的时间决定。
  • 原始时间戳:日志的时间属性由原始日志中时间戳决定。

8.1 采集时间作为日志的时间属性

保持采集时间状态为开启状态即可,如下图所示:

8.2 日志的原始时间戳作为日志时间属性

关闭采集时间状态,填写原始时间戳的时间键以及对应的时间解析格式,转换格式支持strftime的所有函数。

这里举例说明时间格式解析规则填写:
例1:日志样例原始时间戳:10/Dec/2017:08:00:00,解析格式为:%d/%b/%Y:%H:%M:%S
例2:日志样例原始时间戳:2017-12-10 08:00:00,解析格式为:%Y-%m-%d %H:%M:%S
例3:日志样例原始时间戳:12/10/2017, 08:00:00,解析格式为:%m/%d/%Y, %H:%M:%S

注意:

日志时间支持以秒为单位,若时间格式填写错误日志时间将以采集时间为准。

9. 过滤器条件

过滤器旨在您根据业务需要添加日志采集过滤规则,帮助您筛选出有价值的日志数据。过滤规则为 Perl 正则表达式,所创建的过滤规则为命中规则,即匹配上正则表达式的日志才会被采集上报。

分隔符格式日志需要根据所自定义的的键值对来配置过滤规则。例如,样例日志使用分隔符模式解析后,您希望 status 字段为 400 或 500 的所有日志数据被采集,那么 key 处配置 status,过滤规则处配置 400|500。

注意:

多条过滤规则之间关系是"与"逻辑;若同一 key 名配置多条过滤规则,规则会被覆盖。

10. 检索结果

登录 日志服务控制台,左侧选择日志检索,选择日志集与日志主题,单击【搜索】,即可检索日志。

注意:

检索必须开启索引配置,否则无法进行检索。