Hi, i need help in constructing the grok pattern for the following logs.
had asked the same question earlier here-
Hi, I need help constructing the grok pattern for the following log messages
Fri Mar 18 17:43:27 2022 : Info: Debugger not attached
Fri Mar 18 17:43:27 2022 : Info: Loaded virtual server inner-tunnel
Fri Mar 18 17:43:27 2022 : Info: Loaded virtual server <default>
TIMESTAMP_ISO8601 does not seem to match the format.
new to elk, help would be appreciated
Thank you!
this pattern %{HTTPDERROR_DATE:date}\s:\s%{LOGLEVEL:log}:%{GREEDYDATA:message} works for the following log messages -
Wed Jan 12 07:10:57 2022 : Info: Signalled to terminate
Wed Jan 12 07:10:57 2022 : Info: Exiting normally
Wed Jan 12 07:13:52 2022 : Info: Debugger not attached
but i also have log entries such as-
Wed Jan 12 19:56:01 2022 : Auth: (12) Login OK: [AIR_CANADA_ADG-WAP-BL_1@/<via Auth-Type = Accept>] (from client 127.0.0.1 port 1 cli F0-D5-BF-8D-2B-38 via TLS tunnel)
Wed Jan 12 19:56:01 2022 : Auth: (12) Login OK: [AIR_CANADA_ADG-WAP-BL_1@/<via Auth-Type = eap>] (from client 127.0.0.1 port 1 cli F0-D5-BF-8D-2B-38)
need help constructing the pattern for these entries as Auth is not recognized as a LOG LEVEL
Thanks in advance
Hello @anushka1203
Hope this below GROK pattern will help you. Attaching screenshot for your reference
%{DAY:day} %{MONTH:month} %{MONTHDAY:date} %{TIME:time} %{YEAR:year} : %{WORD:loglevel}: %{GREEDYDATA:message}
Keep Posted !!! Thanks !!!
thank you so much this works. but may i know how I can retrieve further fields when the loglevel is Auth?
Wed Jan 12 19:56:01 2022 : Auth: (12) Login OK: [AIR_CANADA_ADG-WAP-BL_1@/<via Auth-Type = eap>] (from client 127.0.0.1 port 1 cli F0-D5-BF-8D-2B-38)
as in if i need the number 12 extracted in a field called number and OK as a value in a field called login status
Hello @anushka1203
if you further would like to extract field , as per this below mentioned grok pattern "loglevel" is Auth then you have to use field reference . for more information check the if condition in the below page. this below pattern would not be a match for info .
For Further field extraction as you requested
%{DAY:day} %{MONTH:month} %{MONTHDAY:date} %{TIME:time} %{YEAR:year} : %{WORD:loglevel}: \(%{NUMBER:number}\)\s* %{DATA:login_status} %{DATA:value}: %{GREEDYDATA:message}
Keep Posted!!! Thanks !!!
Hello @anushka1203
if [loglevel] == "Auth" {
grok {
match =>
{
"message" => "%{DAY:day} %{MONTH:month} %{MONTHDAY:date} %{TIME:time} %{YEAR:year} : %{WORD:loglevel}: \(%{NUMBER:number}\)\s* %{DATA:login_status} %{DATA:value}: %{GREEDYDATA:message}"
}
Hope this helps !!! Keep Posted !!! Thanks
}
Hi @sudhagar_ramesh
Sorry for the late reply, this works. Thank you so much!
1 Like
system
(system)
Closed
July 1, 2022, 9:09am
9
This topic was automatically closed 28 days after the last reply. New replies are no longer allowed.