操作场景
分隔符日志是指一条日志数据可以根据指定的分隔符将整条日志进行结构化处理,每条完整的日志以换行符\\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]
操作步骤
登录控制台
2. 在左侧导航栏中,单击日志主题,进入日志主题管理页面。
创建日志主题
1. 单击创建日志主题。
2. 在弹出的对话框中,将“日志主题名称”填写为“test-separator”,单击确定,即可新增日志主题。
机器组管理
1. 日志主题创建成功后,进入该日志主题管理页面。
2. 选择采集配置页签,在“LogListener采集配置”单击新增,选择需要采集的日志数据源格式。
3. 在“机器组管理”页面,勾选需要与当前日志主题进行绑定的机器组,单击下一步。
即可进入采集配置阶段,更多详情请参阅 管理机器组。 采集配置
在“采集配置”页面,填写采集规则名称,并根据日志采集路径格式填写“采集路径”。
日志采集路径格式:[目录前缀表达式]/**/[文件名表达式]
。
填写日志采集路径后,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 开头命名的日志文件 |
注意:
Loglistener 2.3.9及以上版本才可以添加多个采集路径。
暂不支持上传的日志内容中含有多种文本格式,可能会导致写入失败,例如 key:"{"substream":XXX}"。
建议配置采集路径为 log/*.log
,rename日志轮转后的老文件命名为 log/*.log.xxxx
。
默认情况下,一个日志文件只能被一个日志主题采集。如果一个文件需要对应多个采集配置,请给源文件添加一个软链接,并将其加到另一组采集配置中。
配置采集策略
全量采集:Loglistener 采集文件时,从文件的开头开始读。
增量采集:Loglistener 采集文件时,只采集文件内新增的内容。
配置分隔符模式
1. 将“提取模式”设置为分隔符。
2. 选择分隔符,并在“日志样例”文本框中,输入日志样例,单击提取。
系统根据确定的分隔符将日志样例进行切分,并展示在抽取结果栏中,您需要为每个字段定义唯一的 key。目前,日志采集支持多种分隔符,常见的分隔符有:空格、制表符、逗号、分号、竖线,若您的日志数据所采用的分隔符是其他符号,例如 :::
,也可以通过自定义分词符进行解析。
配置采集时间
说明:
日志时间单位为:秒,若时间格式填写错误日志时间将以采集时间为准。
日志的时间属性有两种方式来定义:采集时间和原始时间戳。
采集时间:日志的时间属性由日志服务 CLS 采集该条日志的时间决定。
原始时间戳:日志的时间属性由原始日志中时间戳决定。
采集时间作为日志的时间属性
保持采集时间状态为开启状态即可。
日志的原始时间戳作为日志时间属性
关闭采集时间状态,在时间键和时间格式解析处,填写原始时间戳的时间键以及对应的时间解析格式。时间解析格式详情参见 配置时间格式。 这里举例说明时间格式解析规则填写:
例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
。
注意:
日志时间支持以秒为单位,若时间格式填写错误日志时间将以采集时间为准。
配置过滤器条件
过滤器旨在您根据业务需要添加日志采集过滤规则,帮助您筛选出有价值的日志数据。过滤规则为 Perl 正则表达式,所创建的过滤规则为命中规则,即匹配上正则表达式的日志才会被采集上报。
分隔符格式日志需要根据所自定义的键值对来配置过滤规则。例如,样例日志使用分隔符模式解析后,您希望 status 字段为 400 或 500 的所有日志数据被采集,那么 key 处配置 status,过滤规则处配置 400|500。
注意:
多条过滤规则之间关系是"与"逻辑;若同一 key 名配置多条过滤规则,规则会被覆盖。
配置上传解析失败日志
建议开启上传解析失败日志。开启后,Loglistener 会上传各式解析失败的日志。若关闭上传解析失败日志,则会丢弃失败的日志。
开启后需要配置解析失败的 Key 值(默认为 LogParseFailure),所有解析失败的日志,均以输入内容作为键名称(Key),原始日志内容作为值(Value)进行上传。
索引配置
1. 单击下一步,进入“索引配置”页面。
2. 在“索引配置”页面,设置如下信息。
索引状态:确认是否开启。
全文索引:确认是否需要设置大小写敏感。
全文分词符:默认为“@&()='",;:<>[]{}/ \\n\\t\\r”,确认是否需要修改。
键值索引:默认关闭,您可根据 key 名按需进行字段类型、分词符以及是否开启统计分析的配置。若您需要开启键值索引,可将 设置为 。 3. 单击提交,完成采集配置。
相关操作
本页内容是否解决了您的问题?