Похожие чаты

Всем привет, есть вопрос по дупликации сообщений в полях после

обработки grok фильтрами в Logstash.
Кейс следующий: множество сервисов посылает различного рода логи в Logstah с помощью Filebeat, в Logstash пайплайне определяется тип сервиса и на основании этого, к лог-лайну применяются grok фильтры, например:
filter {
if "api_access" in [service_name] {
grok {
match => { "message" => \[%{DATA:IP_address}\]\[%{DATA:User_ID}\]" }
}
grok {
match => { "message" => "\[%{DATA:IP_address}\]\[%{DATA:User_ID}\]\[%{DATA:Session_ID}\]" }
}
grok {
match => { "message" => "\[%{DATA:IP_address}\]\[%{DATA:User_ID}\]\[%{DATA:Session_ID}\]\[%{DATA:loglevel}\] ExecutionTime = %{NUMBER:exec_time}" }
}
grok {
match => { "message" => "\[%{DATA:IP_address}\]\[%{DATA:User_ID}\]\[%{DATA:Session_ID}\]\[%{DATA:loglevel}\]\[%{DATA:category}\](?<log_message>%{GREEDYDATA})" }
}
}
else if {check other services}
}
Примеры немного урезаны чтобы повысить читаемость.
Идея была такова: последний Grok фильтр является общим, т.е. он применится в последнюю очередь и всё равно обработает лог даже если предыдущие фильтры не подошли.
Как я понимаю, проблема в том, что к сообщению поочередно применятся каждый grok фильтр, в конечном итоге у меня несколько одинаковых значений в IP_address, User_ID, Session_ID, loglevel и т.д.
Пробовал использовать break_on_match с true/false, но результат идентичный, данные дуплицированы.
Подскажите пожалуйста, как это можно исправить сохранив при этом идею множества Grok фильтров?
Спасибо.

2 ответов

55 просмотров
Pavel-V Автор вопроса

Для потомков так сказать: Решил кейс, необходимо было правильно установить порядок Grok фильтров и заключить их в if условия с проверкой на наличие _grokparsefailure in [tags], т.е. если есть проблема с парсингом -> двигаемся дальше по условию, если нет, оставляем последнее отфильтрованное сообщение

Pavel-V Автор вопроса
Pavel V
Для потомков так сказать: Решил кейс, необходимо б...

Также добавлю, что можно обойтись и другим методом, более быстрым, распарсив логлайн сначала жадным Grok фильтром через {GREEDYDATA:log_message} например и затем уже обрабатывать данные из log_message в последующих Grok фильтрах.

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
@Benzenoid can you tell me the easiest, and safest way to bu.y HEX now?
Živa Žena
20
This is a question from my wife who make a fortune with memes 😂😂 About the Migration and Tokens: 1. How will the old tokens be migrated to the new $LGCYX network? What is th...
🍿 °anton°
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
What is the Dex situation? Agora team started with the Pnetwork for their dex which helped them both with integration. It’s completed but as you can see from the Pnetwork ann...
Ben
1
Гайс, вопрос для разносторонее развитых: читаю стрим с юарта, нада выделять с него фреймы с определенной структурой, если ли чо готовое, или долбаться с ринг буффером? нада у...
Vitaly
9
Anyone knows where there are some instructions or discort about failed bridge transactions ?
Jochem
21
@lozuk how do I get my phex copies of my ehex from a atomic wallet, to move to my rabby?
Justfrontin 👀
11
Карта сайта