我有一个执行有状态处理的微服务。应用程序从输入主题构造一个kstream,执行一些有状态处理,然后将数据写入输出主题。
我将在同一组中运行其中3个应用程序。我需要存储3个参数,当微服务停止时,接管的微服务可以查询sharedstatestore并在崩溃的服务停止的地方继续。
我正在考虑将这3个参数推入statestore,并在其他微服务接管时查询数据。从我的研究中,我看到了很多例子,当人们使用状态存储执行事件计数时,但这并不是我想要的,有人知道一个例子或者什么是解决这个问题的正确方法吗?
我有一个执行有状态处理的微服务。应用程序从输入主题构造一个kstream,执行一些有状态处理,然后将数据写入输出主题。
我将在同一组中运行其中3个应用程序。我需要存储3个参数,当微服务停止时,接管的微服务可以查询sharedstatestore并在崩溃的服务停止的地方继续。
我正在考虑将这3个参数推入statestore,并在其他微服务接管时查询数据。从我的研究中,我看到了很多例子,当人们使用状态存储执行事件计数时,但这并不是我想要的,有人知道一个例子或者什么是解决这个问题的正确方法吗?
1条答案
按热度按时间q9rjltbz1#
所以你要做两件事:
答。服务停止时必须存储以下参数:
如果您想以一种简单的方式完成它,那么您所要做的就是在与状态存储相关联的主题中编写一条消息(您正在使用
KTable
). 使用kafka producer api或KStream
(可能是kTable.toStream()
)就这样。否则,您可以手动创建状态存储:
然后在转换器或处理器中使用它来添加项目;您必须在转换器/处理器中声明:
并初始化
stateStore
变量:然后使用
stateStore
变量:b。读取服务接收中的参数:
你可以和Kafka消费者一起做,但Kafka流你首先要让商店可用;最简单的方法是创建一个ktable;然后,您必须获得使用ktable自动创建的可查询存储名称;那你就得真正进入商店;然后从存储中提取一个记录值(即,通过其键提取一个参数值)。