随笔 - 911  文章 - 5  评论 - 94  阅读 - 243万

Logstash grok正则调试

1.为Logstash添加一个配置文件dnsquery.conf,如下

复制代码
input {
  kafka {
    add_field => { "es_index_name" => "dns-query" }
    bootstrap_servers => "10.0.8.1:9092"
    topics  => "dns-query"
    consumer_threads => 9
    codec => json {
        charset => "UTF-8"
    }
  }
}

filter {
    if [es_index_name] == "ex-iis" {
        grok {
            match => { "message" => "%{DATA:date_time}\s*%{IPV4:s_ip}\s*%{WORD:cs_method}\s*%{URIPATH:cs_uri_stem}\s*(?<cs_uri_query>([=-_;&\S+]*))\s*%{BASE10NUM:s_port}\s*(?<cs_username>([.\S+]*))\s*%{IPV4:c_ip}\s*(?<cs_user_agent>([=-_;&/\S+]*))\s*(?<cs_referer>([=-_;&/\S+]*))\s*%{BASE10NUM:cs_status}\s*%{BASE10NUM:cs_substatus}\s*%{BASE10NUM:cs_win32_status}\s*%{BASE10NUM:time_taken}" }
    }
        mutate {    
            remove_field => ["agent.ephemeral_id", "agent.id", "_score", "_id", "agent.type",  "agent.version", "log.offset"]
            remove_field => ["message"]
    }
    }

    else if [es_index_name] == "dns-query" {     
        grok {         
            match => { "message" => "(?<date_time>\d{4}/\d{1,2}/\d{1,2}\s*[0-9:]{7,8})\s*(?<ThreatID>[0-9A-Za-z]{4})\s*%{NOTSPACE:Context}\s*(?<PacketId>\S+)\s*%{NOTSPACE:UDPTCP}\s*%{NOTSPACE:SendReceive}\s*%{IP:ClientIP}\s*(?<Xid>\S+)\s*(?<QR>\S+)\s*(?<Opcode>\S+)\s*(?<Flags>(\[.*?\]))\s*(?<ResponseCode>\S+)\s*(?<QueryContent>\S+)" }
     }
        mutate {    
            gsub => ["QueryContent","\(.*?\)",".","QueryContent","^.","","QueryContent",".$",""]  #多次替换,先替换所有小括号为点,然后替换开头的点为空,再替换结尾的点为空
            remove_field => ["agent.ephemeral_id", "agent.id", "_score", "_id", "agent.type",  "agent.version", "log.offset"]
            remove_field => ["message"]
     }
     } 


    else {
        mutate {
            remove_field => ["beat", "@version"]
        }
    }
}

output {
  # 调试控制台输出
   stdout { codec => rubydebug { metadata => true } }
}
复制代码

2. 启动一个logstash进程,指定该配置文件 /usr/local/logstash/bin/logstash -f /usr/local/logstash/config/dnsquery.conf ,在前台运行

3.客户端正常收集到日志后,logstash前台会有日志显示

grok正则调试:

 

posted on   momingliu11  阅读(304)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示