Morphline readMultiLine Commands使用
来源:互联网 发布:高仿鞋进货渠道网络 编辑:程序博客网 时间:2024/06/15 19:31
readMultiLIne是一个多行日志解析工具,能够将一个多行的输入日志Record分解为多个输出Records,一行日志对应一个Record。
readMultiLine还可以依据正则表达式(regex)匹配的结果,将输入Record中的多行符合regex匹配规则的日志合并为一个Record。readMultiLine的输出为一个“message”标记的字串串。
readMultiLine支持regex、what和negate参数,regex参数定义了输入Record中日志的开始行和需要合并的行,本文以regex参数为例,介绍readMultiLine的用法,其他参数采用默认设置。
在Morphline配置文件中,readMultiLine的参数定义如下
morphlines: [ { id: morphline1 importCommands : ["org.kitesdk.**", "com.stratio.morphlines.**"] commands: [ { # parse log with stack traces readMultiLine { regex : "(^.<strong>+Exception</strong>: .+)|(^\\s+<strong>at </strong>.+)|(^\\s+\\.\\.\\. \\d+ more)|(^\\s*<strong>Caused by</strong>:.+)" what : previous charset : UTF-8 } # parse sessions; begin new record when we find a line that starts with "Started session" readMultiLine { regex : "<strong>Started session.*</strong>" what : next charset : UTF-8 } } { logInfo { format : "Output record: {}", args : ["@{}"] } } ] }]针对一个多行日志
{message = [messge0 - I am in Line 1 of the Record 0 \n” + “at feild 0 -- Warning Message described in Line 2 of Record 0 \n” + "Started session. messge1 - I am a line (Line3) a new Record 1”]}
Morphlne输入2个Records:
Record 0: {message = [messge0 - I am in Line 1 of the Record 0 \n at feild 0 -- Warning Message described in Line 2 of Record 0]}
Record 1: {message = [Started session. messge1 - I am a line (Line3) a new Record 1]}
其他参数的介绍参考http://kitesdk.org/docs/1.1.0/morphlines/morphlines-reference-guide.html#readMultiLine
0 0
- Morphline readMultiLine Commands使用
- flume学习(十):使用Morphline Interceptor
- flume学习(十):使用Morphline Interceptor
- flume学习(十):使用Morphline Interceptor
- flume学习(九):使用Morphline Interceptor
- TSO/E Commands HELP 使用
- commands
- Commands
- commands
- Domino notes 中 使用URL Commands
- TFS 无法使用,显示 "No Commands Available."
- Domino notes 中 使用URL Commands
- 如何编写Flume-ng-morphline-avro-sink
- 重写Flume-NG-morphline-avro-sink
- 日志系统之Flume采集加morphline解析
- NRT日志系统:flume+morphline+solr+hue配置
- 日志系统之Flume采集加morphline解析
- Linux Commands
- ListView置顶问题
- oracle 12c:新特性-会话级序列
- java正则表达式-常见符号
- C语言入门(二)主菜单操作
- 洞穴逃跑-精灵王子
- Morphline readMultiLine Commands使用
- Hibernate注解的使用
- 延长FLASH和EEPROM芯片写入次数的小方法
- nodejs使用nodejs创建简单的静态文件服务器
- linux下mount挂载设备
- 数据类型 以及 每种数据的二进制范围
- Eclipse将引用了第三方jar包的Java项目打包成jar文件的两种方法
- qt#5 QObject: Cannot create children for a parent that is in a different thread.
- java算法——冒泡法排序