我的 kafka 主题是以这种格式推送数据(来自collectd):
[{"values":[100.000080140372],"dstypes":["derive"],"dsnames":["value"],"time":1529970061.145,"interval":10.000,"host":"k5.orch","plugin":"cpu","plugin_instance":"23","type":"cpu","type_instance":"idle","meta":{"network:received":true}}]
它是数组、整数和浮点数的组合……整个东西都在一个 json 数组中。结果,我有一段时间使用ksql对这些数据做任何事情。
当我创建一个“默认”流时
create stream cd_temp with (kafka_topic='ctd_test', value_format='json');
我得到这个结果:
ksql> describe cd_temp;
Field | Type
-------------------------------------
ROWTIME | BIGINT (system)
ROWKEY | VARCHAR(STRING) (system)
-------------------------------------
任何选择都将返回 ROWTIME 和 ROWKEY 的 8 位十六进制值。
我花了一些时间试图提取 json 字段无济于事。我担心的是:
ksql> print 'ctd_test' from beginning;
Format:JSON
com.fasterxml.jackson.databind.node.ArrayNode cannot be cast to com.fasterxml.jackson.databind.node.ObjectNode
这个主题可能不能在ksql中使用吗?是否有一种技术可以解开外部数组以获取内部有趣的位?