Class StreamOperatorStateHandler
- java.lang.Object
-
- org.apache.flink.streaming.api.operators.StreamOperatorStateHandler
-
@Internal public class StreamOperatorStateHandler extends Object
Class encapsulating various state backend handling logic forStreamOperatorimplementations.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static interfaceStreamOperatorStateHandler.CheckpointedStreamOperatorCustom state handling hooks to be invoked byStreamOperatorStateHandler.
-
Field Summary
Fields Modifier and Type Field Description protected static org.slf4j.LoggerLOG
-
Constructor Summary
Constructors Constructor Description StreamOperatorStateHandler(StreamOperatorStateContext context, org.apache.flink.api.common.ExecutionConfig executionConfig, org.apache.flink.core.fs.CloseableRegistry closeableRegistry)
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description voiddispose()ObjectgetCurrentKey()<K> org.apache.flink.runtime.state.KeyedStateBackend<K>getKeyedStateBackend()Optional<org.apache.flink.api.common.state.KeyedStateStore>getKeyedStateStore()org.apache.flink.runtime.state.OperatorStateBackendgetOperatorStateBackend()<N,S extends org.apache.flink.api.common.state.State,T>
SgetOrCreateKeyedState(org.apache.flink.api.common.typeutils.TypeSerializer<N> namespaceSerializer, org.apache.flink.api.common.state.StateDescriptor<S,T> stateDescriptor)protected <S extends org.apache.flink.api.common.state.State,N>
SgetPartitionedState(N namespace, org.apache.flink.api.common.typeutils.TypeSerializer<N> namespaceSerializer, org.apache.flink.api.common.state.StateDescriptor<S,?> stateDescriptor)Creates a partitioned state handle, using the state backend configured for this task.voidinitializeOperatorState(StreamOperatorStateHandler.CheckpointedStreamOperator streamOperator)voidnotifyCheckpointAborted(long checkpointId)voidnotifyCheckpointComplete(long checkpointId)static org.apache.flink.runtime.state.SnapshotStrategyRunner<org.apache.flink.runtime.state.KeyedStateHandle,? extends org.apache.flink.runtime.state.FullSnapshotResources<?>>prepareCanonicalSavepoint(org.apache.flink.runtime.state.CheckpointableKeyedStateBackend<?> keyedStateBackend, org.apache.flink.core.fs.CloseableRegistry closeableRegistry)voidsetCurrentKey(Object key)OperatorSnapshotFuturessnapshotState(StreamOperatorStateHandler.CheckpointedStreamOperator streamOperator, Optional<InternalTimeServiceManager<?>> timeServiceManager, String operatorName, long checkpointId, long timestamp, org.apache.flink.runtime.checkpoint.CheckpointOptions checkpointOptions, org.apache.flink.runtime.state.CheckpointStreamFactory factory, boolean isUsingCustomRawKeyedState)
-
-
-
Constructor Detail
-
StreamOperatorStateHandler
public StreamOperatorStateHandler(StreamOperatorStateContext context, org.apache.flink.api.common.ExecutionConfig executionConfig, org.apache.flink.core.fs.CloseableRegistry closeableRegistry)
-
-
Method Detail
-
initializeOperatorState
public void initializeOperatorState(StreamOperatorStateHandler.CheckpointedStreamOperator streamOperator) throws Exception
- Throws:
Exception
-
snapshotState
public OperatorSnapshotFutures snapshotState(StreamOperatorStateHandler.CheckpointedStreamOperator streamOperator, Optional<InternalTimeServiceManager<?>> timeServiceManager, String operatorName, long checkpointId, long timestamp, org.apache.flink.runtime.checkpoint.CheckpointOptions checkpointOptions, org.apache.flink.runtime.state.CheckpointStreamFactory factory, boolean isUsingCustomRawKeyedState) throws org.apache.flink.runtime.checkpoint.CheckpointException
- Throws:
org.apache.flink.runtime.checkpoint.CheckpointException
-
prepareCanonicalSavepoint
@Nonnull public static org.apache.flink.runtime.state.SnapshotStrategyRunner<org.apache.flink.runtime.state.KeyedStateHandle,? extends org.apache.flink.runtime.state.FullSnapshotResources<?>> prepareCanonicalSavepoint(org.apache.flink.runtime.state.CheckpointableKeyedStateBackend<?> keyedStateBackend, org.apache.flink.core.fs.CloseableRegistry closeableRegistry) throws Exception
- Throws:
Exception
-
notifyCheckpointComplete
public void notifyCheckpointComplete(long checkpointId) throws Exception- Throws:
Exception
-
notifyCheckpointAborted
public void notifyCheckpointAborted(long checkpointId) throws Exception- Throws:
Exception
-
getKeyedStateBackend
public <K> org.apache.flink.runtime.state.KeyedStateBackend<K> getKeyedStateBackend()
-
getOperatorStateBackend
public org.apache.flink.runtime.state.OperatorStateBackend getOperatorStateBackend()
-
getOrCreateKeyedState
public <N,S extends org.apache.flink.api.common.state.State,T> S getOrCreateKeyedState(org.apache.flink.api.common.typeutils.TypeSerializer<N> namespaceSerializer, org.apache.flink.api.common.state.StateDescriptor<S,T> stateDescriptor) throws Exception- Throws:
Exception
-
getPartitionedState
protected <S extends org.apache.flink.api.common.state.State,N> S getPartitionedState(N namespace, org.apache.flink.api.common.typeutils.TypeSerializer<N> namespaceSerializer, org.apache.flink.api.common.state.StateDescriptor<S,?> stateDescriptor) throws ExceptionCreates a partitioned state handle, using the state backend configured for this task.- Throws:
IllegalStateException- Thrown, if the key/value state was already initialized.Exception- Thrown, if the state backend cannot create the key/value state.
-
setCurrentKey
public void setCurrentKey(Object key)
-
getCurrentKey
public Object getCurrentKey()
-
getKeyedStateStore
public Optional<org.apache.flink.api.common.state.KeyedStateStore> getKeyedStateStore()
-
-