繁体   English   中英

Logstash红宝石过滤器和事件字段

[英]Logstash ruby filter and event fields

我正在尝试从传入的logstash事件中捕获IP地址字段,并将其传递给Shell脚本以与静态黑名单进行比较。 问题是,我能够使用puts打印IP地址,但无法捕获以将其传递给ruby过滤器中的system()调用。 这是我的示例配置。

我正在使用Logstash 2.0

Sample input = {"name":"xyz", "source_ip":"8.8.8.8"}

input {

        stdin {
        codec => json
        }
}

filter {

        ruby {
        code => "
        # puts event['source_ip']  # This always works
        ip = event['source_ip']
        system('echo ${ip}')       # This echoes ${ip} instead of value !
        "
        }
}

我也尝试过' echo #${ip} ',但是它只显示0

使用以下语法而不是system('echo ${ip}')来运行Shell命令:

puts `echo #{ip}`

从Ruby调用Shell命令

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM