概述
多行全文日志是指一条完整的日志数据跨占多行(例如 Java 程序日志)。在这种情况下,以换行符\n
为日志的结束标识符就显得有些不合理,为了能让日志系统明确区分开每条日志,采用首行正则的方式进行匹配,当某行日志匹配上预先设置的正则表达式,就认为是一条日志的开头,而下一个行首出现作为该条日志的结束标识符。
多行全文也会设置一个默认的键值__CONTENT__
,但日志数据本身不再进行日志结构化处理,也不会提取日志字段,日志属性的时间项由日志采集的时间决定。
示例
假设您的一条多行日志原始数据为:
10.20.20.10 - - [Tue Jan 22 14:24:03 CST 2019 +0800] GET /online/sample HTTP/1.1 127.0.0.1 200 628 35 http://127.0.0.1/group/1
Mozilla/5.0 (Windows NT 10.0; WOW64; rv:64.0) Gecko/20100101 Firefox/64.0 0.310 0.310
该条日志最终被日志服务结构化处理为:
__CONTENT__:10.20.20.10 - - [Tue Jan 22 14:24:03 CST 2019 +0800] GET /online/sample HTTP/1.1 127.0.0.1 200 628 35 http://127.0.0.1/group/1 \nMozilla/5.0 (Windows NT 10.0; WOW64; rv:64.0) Gecko/20100101 Firefox/64.0 0.310 0.310
采集配置
1. 登录控制台
登录 日志服务控制台,在左侧导航栏中,单击【日志集管理】。
2. 新建 LogListener 采集
选择目标日志集,单击【新建日志主题】,输入日志主题名称:test-mtext ,单击【确定】。
3. 配置 LogListener 采集
- 选择 LogListener 采集的日志主题,进入日志主题管理页面。
- 单击【采集配置】页签,并单击采集状态开关,进入到采集配置编辑模式。
- 在 LogListener 采集配置项中,单击【添加配置】,进入 Agent 配置页面。
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 开头命名的日志文件 |
注意:
- 多层目录和通配符配置方式依赖2.2.2及以上版本的 loglistener,为兼容低版本 loglistener 路径配置修改方式,用户可切换旧配置进行历史修改,旧采集路径方式不支持多目录采集。
- 一个日志文件只能被一个日志主题采集。
- LogListener 不支持监听软连接方式的日志文件和 NFS、CIFS 等共享文件目录上的日志文件。
5. 关联机器组
从机器组列表中选择目标机器组,将其与当前日志主题进行关联,值得注意的是,关联的机器组与日志主题所在的地域需保持一致。操作详情请参阅 如何创建机器组 文档。
6. 多行全文模式选择
- 单击【下一步】,配置日志解析方式。
- 【提取模式】,请选择【多行全文】,如下图所示:
自动生成多行全文格式:
a. 键值提取模式选择多行全文。
b. 将日志文件中单条多行日志粘贴至对话框内,系统会自动提取将匹配的首行内容,并高亮显示。
c. 选择自动生成,单击【自动生成】。
d. 自动填充正则表达式,完成配置。
手动输入多行全文格式:
a. 键值提取模式选择多行全文。
b. 将日志文件中单条多行日志粘贴至对话框内,系统会自动将匹配的首行内容,并高亮显示。
c. 手动输入首行正则表达式,单击【验证】。
d. 验证通过,完成配置。
7. 过滤器条件
过滤器旨在您根据业务需要添加日志采集过滤规则,帮助您筛选出有价值的日志数据。过滤规则为 Perl 正则表达式,所创建的过滤规则为命中规则,即匹配上正则表达式的日志才会被采集上报。
多行全文模式下,默认使用__CONTENT__
作为全文的键(key)名。例如,多行全文日志样例格式为:
10.20.20.10 - - [Tue Jan 22 14:24:03 CST 2019 +0800] GET /online/sample HTTP/1.1 127.0.0.1 200 628 35 http://127.0.0.1/group/1
Mozilla/5.0 (Windows NT 10.0; WOW64; rv:64.0) Gecko/20100101 Firefox/64.0 0.310 0.310
您希望采集10.20.20.10
这台机器的所有日志,则 key 处填写__CONTENT__
,过滤规则配置10.20.20.10.*
注意:多条过滤规则之间关系是"与"逻辑;若同一 key 名配置多条过滤规则,规则会被覆盖。
8. 检索结果
登录 日志服务控制台,单击【日志检索】,选择日志集与日志主题,单击【搜索】,系统将开始检索日志。
注意:检索必须开启索引配置,否则无法进行检索。