我正在尝试使用Grok解析以下字符串;
2018-06-08 13:26:02.002851: <action cmd="run" options="IGNORE_ERROR" path="/usr/lib/vmware/likewise/bin/lw-lsa get-metrics"> (/etc/vmware/vm-support/ad.mfx) took 0.000 sec
我想将以上内容最终分成几列,例如TIMESTAMP, ACTION, OPTIONS, PATH
等-我已经尝试了多种组合,但到目前为止都失败了。
答案 0 :(得分:0)
以上日志的格罗模式:->
%{TIMESTAMP_ISO8601:time}:%{SPACE}\<%{WORD:action}%{SPACE} %{DATA:kvpairs}\>%{SPACE}\(%{DATA:path_2}\)%{SPACE}took%{SPACE}%{NUMBER:time_taken}%{SPACE}%{WORD:time_unit}
在上述grok模式中,我在名为kvpairs的事件中捕获了cmd
,options
和path
。这是因为可以使用kv
过滤器在logstash中轻松提取这些键值对。因此,您的过滤器配置如下所示:->
filter{
grok(
match => { "message" => "%{TIMESTAMP_ISO8601:timestamp}:%{SPACE}\<%{WORD:action}%{SPACE} %{DATA:kvpairs}\>%{SPACE}\(%{DATA:path_2}\)%{SPACE}took%{SPACE}%{NUMBER:time_taken}%{SPACE}%{WORD:time_unit}"}
)
kv{
source => "kvpairs"
}
date{
match => ["timestamp","yyyy-MM-dd HH:mm:ss.SSS"]
}
}
kv
过滤器默认将空格作为定界符,并将提取列cmd
,options
和path
。
date
过滤器将使@timestamp
变量。