首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Kafka Streams KV状态存储中的空值

Kafka Streams KV状态存储中的空值
EN

Stack Overflow用户
提问于 2019-09-17 21:07:27
回答 1查看 1K关注 0票数 0

我正在尝试为Kafka Streams开发一个交互式查询应用程序。这是一个简单的基于count()的状态存储。但我看到的问题是,一旦我将应用程序扩展到多个实例,我就开始获得一些键的空值

代码语言:javascript
复制
KStream<String, String> inputStream = builder.stream(INPUT_TOPIC, Consumed.with(Serdes.String(), Serdes.String())); //key: foo, value:bar
inputStream.groupByKey(Grouped.with(Serdes.String(), Serdes.String()))
                .count(Materialized.<String, Long, KeyValueStore<Bytes, byte[]>>as(STATE_STORE_NAME)
                        .withKeySerde(Serdes.String())
                        .withValueSerde(Serdes.Long()));

就测试基于DSL的管道而言,这差不多就是它了。我有一个用于交互式查询的REST端点

代码语言:javascript
复制
KafkaStreams streams = ...;
ReadOnlyKeyValueStore<String, Long> averageStore = streams.store(storeName, QueryableStoreTypes.<String, Long>keyValueStore());
Long count = averageStore.get(word);

count为空-此行为仅适用于某些键。并且这与密钥是否存在于本地无关

EN

回答 1

Stack Overflow用户

发布于 2019-12-28 07:29:32

当您扩展Kafka Streams应用程序时,只有全局表在所有实例上都是可见的。对于常规KTable,整个数据集只有一部分可用。

您需要查找关键的元数据,并将REST调用重定向到相应的实例,如here所述。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/57974923

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档