logstash – 使用convert in mutate将所有以“id”结尾的字段转换为整数?

目前我在我的logstash配置文件中做了类似的事情:

filter {
    ...
    mutate {
        ...
        convert => {
            "blahId" => "integer"
            "blahblahId" => "integer"
            ...
            ...
            "b...blahId" => "integer"
        }
        ...
    }
    ...
}

所以基本上我想将所有以“Id”结尾的字段转换为整数.有没有办法在一行中做到这一点?像“* Id”=> “整数”这样做?

编辑:我试过了

convert => {
    "*Id" => "integer"
}

正如我所料,没有奏效.

也许使用ruby过滤器?

最佳答案
不是具体的答案,但这是我最终做的:

ruby {
        code => "
            fieldArray = event['kvmess'].split('|');
            for field in fieldArray
                name = field.split('=')[0];
                value = field.split('=')[1];
                if value =~ /\A\d+\Z/
                    event[name] = value.to_i
                else
                    event[name] = value
                end
            end
        "
    }

我的kvmess就像“blahId = 123 | blahblahId = 456 | some = thing | b..blahId = 789”.
所以这将所有具有数值的键转换为整数.

有一个插件 – kv专门用于此,但它没有将数据类型更改为int的功能,所以我最终使用这个ruby插件.

转载注明原文:logstash – 使用convert in mutate将所有以“id”结尾的字段转换为整数? - 代码日志