I have logs as bellow and each parameter in log is static. I try to send elastic via logstash and using Grok pattern.But i couldn't see regular logs. I'm not good at grok. How can i write suitable grok code ? In output i want to not see year,mont info and empty GREEDYDATA part.
[2021-12-05 20:57:40,513] INFO - LogCounterMetric Metric Name : apim:response Metric Value: {apiName=ApiExp, proxyResponseCode=200, errorType=null, destination=http://1.1.1.1:11/service.asmx, apiCreatorTenantDomain=carbon.super, platform=Other, apiMethod=POST, apiVersion=1.0, gatewayType=SYNAPSE, apiCreator=admin, responseCacheHit=false, backendLatency=229, correlationId=244a4509-52a6-4f37-921d-5d2fc6e40ca3, requestMediationLatency=365, keyType=SANDBOX, apiId=32154b48-70dc5-4cx5-9dgd-7er32e31bacc, applicationName=DefaultApplication, targetResponseCode=200, requestTimestamp=2021-12-05T20:57:39.823Z, applicationOwner=admin, userAgent=Other, eventType=response, apiResourceTemplate=/*, responseLatency=596, regionId=default, responseMediationLatency=2, userIp=1.1.1.1, applicationId=37d453cc-4425-fd31-gf9c-fcdfae89bbd, apiType=SOAP}
this is i wrote grok code.
\[%{TIMESTAMP_ISO8601:timestamp}\]%{SPACE}%{LOGLEVEL:level} - LogCounterMetric Metric Name : apim:response Metric Value: {%{GREEDYDATA}apiName=%{GREEDYDATA:apiName}, %{GREEDYDATA}proxyResponseCode=%{GREEDYDATA:proxyResponseCode}, %{GREEDYDATA}errorType=%{GREEDYDATA:errorType}, %{GREEDYDATA}destination=%{GREEDYDATA:destination}, %{GREEDYDATA}apiCreatorTenantDomain=%{GREEDYDATA:apiCreatorTenantDomain}, %{GREEDYDATA}platform=%{GREEDYDATA:platform}, %{GREEDYDATA}apiMethod=%{GREEDYDATA:apiMethod}, %{GREEDYDATA}apiVersion=%{GREEDYDATA:apiVersion}, %{GREEDYDATA}gatewayType=%{GREEDYDATA:gatewayType}, %{GREEDYDATA}apiCreator=%{GREEDYDATA:apiCreator}, %{GREEDYDATA}responseCacheHit=%{GREEDYDATA:responseCacheHit}, %{GREEDYDATA}backendLatency=%{GREEDYDATA:backendLatency}, %{GREEDYDATA}correlationId=%{GREEDYDATA:correlationId, %{GREEDYDATA}requestMediationLatency=%{GREEDYDATA:requestMediationLatency}, %{GREEDYDATA}keyType=%{GREEDYDATA:keyType}, %{GREEDYDATA}apiId=%{GREEDYDATA:apiId}, %{GREEDYDATA}applicationName=%{GREEDYDATA:applicationName}, %{GREEDYDATA}targetResponseCode=%{GREEDYDATA:targetResponseCode}, %{GREEDYDATA}requestTimestamp=%{GREEDYDATA:requestTimestamp}, %{GREEDYDATA}applicationOwner=%{GREEDYDATA:applicationOwner}, %{GREEDYDATA}userAgent=%{GREEDYDATA:userAgent}, %{GREEDYDATA}eventType=%{GREEDYDATA:eventType}, %{GREEDYDATA}apiResourceTemplate=%{GREEDYDATA:apiResourceTemplate}, %{GREEDYDATA}responseLatency=%{GREEDYDATA:responseLatency}, %{GREEDYDATA}regionId=%{GREEDYDATA:regionId}, %{GREEDYDATA}responseMediationLatency=%{GREEDYDATA:responseMediationLatency}, %{GREEDYDATA}userIp=%{GREEDYDATA:userIp}, %{GREEDYDATA}applicationId=%{GREEDYDATA:applicationId}, %{GREEDYDATA}apiType=%{GREEDYDATA:apiType}}
--in grok debugger output
{
"timestamp": [
[
"2021-12-05 20:57:40,513"
]
],
"YEAR": [
[
"2021"
]
],
"MONTHNUM": [
[
"12"
]
],
"MONTHDAY": [
[
"05"
]
],
"HOUR": [
[
"20",
null
]
],
"MINUTE": [
[
"57",
null
]
],
"SECOND": [
[
"40,513"
]
],
"ISO8601_TIMEZONE": [
[
null
]
],
"SPACE": [
[
" "
]
],
"level": [
[
"INFO"
]
],
"GREEDYDATA": [
[
"",
"",
"",
"",
"",
"",
"",
"",
"",
"",
"",
"",
"",
"",
"",
"",
"",
"",
"",
"",
"",
"",
"",
"",
"",
"",
"",
""
]
],
"apiName": [
[
"ApiExp"
]
],
"proxyResponseCode": [
[
"200"
]
],
"errorType": [
[
"null"
]
],
"destination": [
[
"http://1.1.1.1:11/service.asmx"
]
],
"apiCreatorTenantDomain": [
[
"carbon.super"
]
],
"platform": [
[
"Other"
]
],
"apiMethod": [
[
"POST"
]
],
"apiVersion": [
[
"1.0"
]
],
"gatewayType": [
[
"SYNAPSE"
]
],
"apiCreator": [
[
"admin"
]
],
"responseCacheHit": [
[
"false"
]
],
"backendLatency": [
[
"229"
]
],
"correlationId": [
[
"244a4509-52a6-4f37-921d-5d2fc6e40ca3, "
]
],
"requestMediationLatency": [
[
"365"
]
],
"keyType": [
[
"SANDBOX"
]
],
"apiId": [
[
"32154b48-70dc5-4cx5-9dgd-7er32e31bacc"
]
],
"applicationName": [
[
"DefaultApplication"
]
],
"targetResponseCode": [
[
"200"
]
],
"requestTimestamp": [
[
"2021-12-05T20:57:39.823Z"
]
],
"applicationOwner": [
[
"admin"
]
],
"userAgent": [
[
"Other"
]
],
"eventType": [
[
"response"
]
],
"apiResourceTemplate": [
[
"/*"
]
],
"responseLatency": [
[
"596"
]
],
"regionId": [
[
"default"
]
],
"responseMediationLatency": [
[
"2"
]
],
"userIp": [
[
"1.1.1.1"
]
],
"applicationId": [
[
"37d453cc-4425-fd31-gf9c-fcdfae89bbd"
]
],
"apiType": [
[
"SOAP"
]
]
}
You can use the option remove_field
of the drop filter to remove the particular fields that is not needed in the output.
More details: