Flink教程(12)-QueryableState

本文介绍了Flink的可查询状态(Queryable State)服务,允许外部系统实时获取Job运行时的状态。详细讲解了QueryableState组件,包括QueryStateClient、QueryableStateClientProxy和QueryableStateServer,并提供了开启服务的方法以及两种设置状态可查询的方式:QueryableStateStream和StateDescriptor。同时,给出了示例代码,展示了如何在Flink应用中实现和查询状态。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

QueryableState

上述案例中,状态后端存储的状态数据我们是没法直接读取的,都是二进制流。Flink提供了一种获取运行时状态的机制,让我们可以实时获取到Job运行时的State。这就是可查询状态(Queryable State)服务,顾名思义就是允许用户从外部系统(如业务系统)中查询Flink作业内部的状态(State)。在一些需要给外部系统开放状态查询的场景可以使用此特性。

QueryableState组件

QueryableStateClient:客户端组件,可以独立于Flink集群运行,用于提交用户查询请求。

QueryableStateClientProxy:代理组件,运行在每个TaskManager上(即在Flink集群中),负责接收客户端的请求。客户端的查询请求通常带一个key,代理组件从JobManager处查得key所属的TaskManager,将客户端请求转发到该TaskManager上运行的QueryableStateServer中,并将用户查询的状态结果转发给客户端。

QueryableStateServer:状态查询组件,运行在每个TaskManager上,负责管理本地状态,处理客户端的查询。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程猿薇茑

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值