Logstash筛选器:从一个聚合值获取Map值,并将其设置为另一个的另一task_id

问题描述

在此情况下:我的日志很少,可以汇总traceID,并且可以正常工作。但是,我也想基于以上汇总之一中的customerid进行汇总。

在以下代码段中,我基于traceid进行了汇总,并且可以正常工作。我在这里保存customerid

aggregate {
       task_id => "%{traceid}"
       code => "
            map['customerid'] = event.get('customerid')
            map['channelid'] = event.get('channelid')"
       map_action => "create"
     }
    }

在另一个日志行处理中,我想使用此映射的customerId创建一个新的aggregate

可能是这样的:

aggregate {
       task_id => "%{map['customerid']}"
       code => "map['it_works'] = 'true'"
       map_action => "create"
     }

但是它失败了:

An unexpected error occurred! {:error=>java.lang.IllegalStateException: org.logstash.FieldReference$IllegalSyntaxException: Invalid FieldReference: `map['customerid']`

有没有办法解决这个问题?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...