Update to what we are currently running in production
This will also process wsgi log outputs from the projects and grab the metadata (response code, time, request id). You can use this to monitor the response time of the apis. Change-Id: I0c061fa7c4ac07fe0789b51d17eee6e89ebe7f86
This commit is contained in:
parent
20aec04358
commit
a183507b44
@ -159,18 +159,71 @@ filter {
|
|||||||
match => { "message" => "(?m)^%{TIMESTAMP_ISO8601:logdate}%{SPACE}%{NUMBER:pid}?%{SPACE}?(?<loglevel>AUDIT|CRITICAL|DEBUG|INFO|TRACE|WARNING|ERROR) \[?\b%{NOTSPACE:module}\b\]?%{SPACE}?%{GREEDYDATA:logmessage}?" }
|
match => { "message" => "(?m)^%{TIMESTAMP_ISO8601:logdate}%{SPACE}%{NUMBER:pid}?%{SPACE}?(?<loglevel>AUDIT|CRITICAL|DEBUG|INFO|TRACE|WARNING|ERROR) \[?\b%{NOTSPACE:module}\b\]?%{SPACE}?%{GREEDYDATA:logmessage}?" }
|
||||||
add_field => { "received_at" => "%{@timestamp}" }
|
add_field => { "received_at" => "%{@timestamp}" }
|
||||||
}
|
}
|
||||||
|
|
||||||
} else if "keystonefmt" in [tags] {
|
|
||||||
grok {
|
|
||||||
# Do multiline matching as the above mutliline filter may add newlines
|
|
||||||
# to the log messages.
|
|
||||||
# TODO move the LOGLEVELs into a proper grok pattern.
|
|
||||||
match => { "message" => "(?m)^%{TIMESTAMP_ISO8601:logdate}%{SPACE}%{NUMBER:pid}?%{SPACE}?(?<loglevel>AUDIT|CRITICAL|DEBUG|INFO|TRACE|WARNING|ERROR) \[?\b%{NOTSPACE:module}\b\]?%{SPACE}?%{GREEDYDATA:logmessage}?" }
|
|
||||||
add_field => { "received_at" => "%{@timestamp}" }
|
|
||||||
}
|
|
||||||
if [module] == "iso8601.iso8601" {
|
if [module] == "iso8601.iso8601" {
|
||||||
#log message for each part of the date? Really?
|
drop {}
|
||||||
drop {}
|
}
|
||||||
|
|
||||||
|
if "keystoneapi" in [tags] {
|
||||||
|
mutate {
|
||||||
|
gsub => ['logmessage',"\"",""]
|
||||||
|
}
|
||||||
|
grok {
|
||||||
|
match => { "logmessage" => "\[\-\] %{NOTSPACE:requesterip} \- \- \[%{NOTSPACE:req_date} %{NOTSPACE:req_time}\] %{NOTSPACE:method} %{NOTSPACE:url_path} %{NOTSPACE:http_ver} %{NUMBER:response} %{NUMBER:bytes} %{NUMBER:seconds}" }
|
||||||
|
add_field => ["api", "keystone"]
|
||||||
|
add_tag => ["apimetrics"]
|
||||||
|
}
|
||||||
|
} else if "novaapi" in [tags] {
|
||||||
|
if [module] == "nova.osapi_compute.wsgi.server" {
|
||||||
|
mutate {
|
||||||
|
gsub => ['logmessage',"\"",""]
|
||||||
|
}
|
||||||
|
grok {
|
||||||
|
match => { "logmessage" => "\[req\-%{NOTSPACE:requestid} %{NOTSPACE:user_id} %{NOTSPACE:tenant}\] %{NOTSPACE:requesterip} %{NOTSPACE:method} %{NOTSPACE:url_path} %{NOTSPACE:http_ver} status\: %{NUMBER:response} len\: %{NUMBER:bytes} time\: %{NUMBER:seconds}" }
|
||||||
|
add_field => ["api", "nova"]
|
||||||
|
add_tag => ["apimetrics"]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if "neutronapi" in [tags] {
|
||||||
|
if [module] == "neutron.wsgi" {
|
||||||
|
if "accepted" not in [logmessage] {
|
||||||
|
mutate {
|
||||||
|
gsub => ['logmessage',"\"",""]
|
||||||
|
}
|
||||||
|
grok {
|
||||||
|
match => { "logmessage" => "\[req\-%{NOTSPACE:requestid} %{NOTSPACE:user_id} %{NOTSPACE:tenant}\] %{NOTSPACE:requesterip} \- \- \[%{NOTSPACE:req_date} %{NOTSPACE:req_time}\] %{NOTSPACE:method} %{NOTSPACE:url_path} %{NOTSPACE:http_ver} %{NUMBER:response} %{NUMBER:bytes} %{NUMBER:seconds}" }
|
||||||
|
add_field => ["api", "neutron"]
|
||||||
|
add_tag => ["apimetrics"]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if "glanceapi" in [tags] {
|
||||||
|
if [module] == "glance.wsgi.server" {
|
||||||
|
mutate {
|
||||||
|
gsub => ['logmessage',"\"",""]
|
||||||
|
}
|
||||||
|
grok {
|
||||||
|
match => { "logmessage" => "\[%{NOTSPACE:requestid} %{NOTSPACE:user_id} %{NOTSPACE:tenant} \- \- \-\] %{NOTSPACE:requesterip} \- \- \[%{NOTSPACE:req_date} %{NOTSPACE:req_time}\] %{NOTSPACE:method} %{NOTSPACE:url_path} %{NOTSPACE:http_ver} %{NUMBER:response} %{NUMBER:bytes} %{NUMBER:seconds}" }
|
||||||
|
add_field => ["api", "glance"]
|
||||||
|
add_tag => ["apimetrics"]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if "novametaapi" in [tags] {
|
||||||
|
mutate {
|
||||||
|
gsub => ['logmessage',"\"",""]
|
||||||
|
}
|
||||||
|
if [module] == "nova.api.ec2" {
|
||||||
|
grok {
|
||||||
|
match => { "logmessage" => "\[%{GREEDYDATA:requestid}\] %{NUMBER:seconds}s %{NOTSPACE:requesterip} %{NOTSPACE:method} %{NOTSPACE:url_path} None\:None %{NUMBER:response} %{GREEDYDATA:user_agent}" }
|
||||||
|
add_field => ["api", "metadata-ec2"]
|
||||||
|
add_tag => ["apimetrics"]
|
||||||
|
}
|
||||||
|
} else if [module] == "nova.metadata.wsgi.server" {
|
||||||
|
grok {
|
||||||
|
match => { "logmessage" => "\[%{GREEDYDATA:requestid}\] %{NOTSPACE:requesterip} %{NOTSPACE:method} %{NOTSPACE:url_path} %{NOTSPACE:http_ver} status\: %{NUMBER:response} len\: %{NUMBER:bytes} time\: %{NUMBER:seconds}" }
|
||||||
|
add_field => ["api", "metadata"]
|
||||||
|
add_tag => ["apimetrics"]
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else if "libvirt" in [tags] {
|
} else if "libvirt" in [tags] {
|
||||||
grok {
|
grok {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user