Using Managed Keyed State

classic Classic list List threaded Threaded
2 messages Options
Reply | Threaded
Open this post in threaded view
|

Using Managed Keyed State

Boris Lublinsky
Documentation https://ci.apache.org/projects/flink/flink-docs-release-1.6/dev/stream/state/state.html#using-managed-keyed-state lists ValueState<T> and List<T>, but their semantics seems to be different. In my tests ValueState<T> is associated with key, but it is not clear to me what List<T> is associated it.
I tried to test List[String] and ValueState[ModelBuffer[String]] and they behave very differently. Can you, please clarify the differences and usage patterns? 

Boris Lublinsky
FDP Architect
[hidden email]
https://www.lightbend.com/

Reply | Threaded
Open this post in threaded view
|

Re: Using Managed Keyed State

Andrey Zagrebin
Hi,

If you ask about keyed state, you probably mean ListState<T>, because in any case List<T> is just java object for a concrete value of state. ListState<T> is also scoped by current record key as ValueState<T> but adds some list specific functionality. They are state object handles. Keyed state is also distributed by key, same way as record processing.

There is also an operator state types which are scoped by the operator, not by any record key. One of them also behaves similar to ListState<T> [1] but not per key. Operator state is distributed between parallel subtasks of the operator.

Best,
Andrey


On 31 Aug 2018, at 12:17, Boris Lublinsky <[hidden email]> wrote:

Documentation https://ci.apache.org/projects/flink/flink-docs-release-1.6/dev/stream/state/state.html#using-managed-keyed-state lists ValueState<T> and List<T>, but their semantics seems to be different. In my tests ValueState<T> is associated with key, but it is not clear to me what List<T> is associated it.
I tried to test List[String] and ValueState[ModelBuffer[String]] and they behave very differently. Can you, please clarify the differences and usage patterns? 

Boris Lublinsky
FDP Architect
[hidden email]
https://www.lightbend.com/