@Internal public abstract class AbstractRuntimeUDFContext extends Object implements RuntimeContext
RuntimeContext
, created by runtime UDF operators.Constructor and Description |
---|
AbstractRuntimeUDFContext(JobInfo jobInfo,
TaskInfo taskInfo,
UserCodeClassLoader userCodeClassLoader,
ExecutionConfig executionConfig,
Map<String,Accumulator<?,?>> accumulators,
Map<String,Future<Path>> cpTasks,
OperatorMetricGroup metrics) |
Modifier and Type | Method and Description |
---|---|
<V,A extends Serializable> |
addAccumulator(String name,
Accumulator<V,A> accumulator)
Add this accumulator.
|
<T> TypeSerializer<T> |
createSerializer(TypeInformation<T> typeInformation)
Create a serializer for a given type.
|
<V,A extends Serializable> |
getAccumulator(String name)
Get an existing accumulator object.
|
<IN,ACC,OUT> |
getAggregatingState(AggregatingStateDescriptor<IN,ACC,OUT> stateProperties)
Gets a handle to the system's key/value aggregating state.
|
String |
getAllocationIDAsString() |
DistributedCache |
getDistributedCache()
Returns the
DistributedCache to get the local temporary file copies of files
otherwise not locally accessible. |
DoubleCounter |
getDoubleCounter(String name)
Convenience function to create a counter object for doubles.
|
Map<String,String> |
getGlobalJobParameters()
Get global job parameters.
|
Histogram |
getHistogram(String name)
Convenience function to create a counter object for histograms.
|
IntCounter |
getIntCounter(String name)
Convenience function to create a counter object for integers.
|
JobInfo |
getJobInfo()
Get the meta information of current job.
|
<T> ListState<T> |
getListState(ListStateDescriptor<T> stateProperties)
Gets a handle to the system's key/value list state.
|
LongCounter |
getLongCounter(String name)
Convenience function to create a counter object for longs.
|
<UK,UV> MapState<UK,UV> |
getMapState(MapStateDescriptor<UK,UV> stateProperties)
Gets a handle to the system's key/value map state.
|
OperatorMetricGroup |
getMetricGroup()
Returns the metric group for this parallel subtask.
|
<T> ReducingState<T> |
getReducingState(ReducingStateDescriptor<T> stateProperties)
Gets a handle to the system's key/value reducing state.
|
<T> ValueState<T> |
getState(ValueStateDescriptor<T> stateProperties)
Gets a handle to the system's key/value state.
|
TaskInfo |
getTaskInfo()
Get the meta information of current task.
|
ClassLoader |
getUserCodeClassLoader()
Gets the ClassLoader to load classes that are not in system's classpath, but are part of the
jar file of a user job.
|
boolean |
isObjectReuseEnabled()
Check if object reuse is enabled.
|
void |
registerUserCodeClassLoaderReleaseHookIfAbsent(String releaseHookName,
Runnable releaseHook)
Registers a custom hook for the user code class loader release.
|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
getBroadcastVariable, getBroadcastVariableWithInitializer, getExternalResourceInfos, hasBroadcastVariable
public AbstractRuntimeUDFContext(JobInfo jobInfo, TaskInfo taskInfo, UserCodeClassLoader userCodeClassLoader, ExecutionConfig executionConfig, Map<String,Accumulator<?,?>> accumulators, Map<String,Future<Path>> cpTasks, OperatorMetricGroup metrics)
public <T> TypeSerializer<T> createSerializer(TypeInformation<T> typeInformation)
RuntimeContext
createSerializer
in interface RuntimeContext
typeInformation
- the type information of the object to be serializedpublic Map<String,String> getGlobalJobParameters()
RuntimeContext
getGlobalJobParameters
in interface RuntimeContext
public boolean isObjectReuseEnabled()
RuntimeContext
isObjectReuseEnabled
in interface RuntimeContext
public OperatorMetricGroup getMetricGroup()
RuntimeContext
getMetricGroup
in interface RuntimeContext
public IntCounter getIntCounter(String name)
RuntimeContext
getIntCounter
in interface RuntimeContext
public LongCounter getLongCounter(String name)
RuntimeContext
getLongCounter
in interface RuntimeContext
public Histogram getHistogram(String name)
RuntimeContext
getHistogram
in interface RuntimeContext
public DoubleCounter getDoubleCounter(String name)
RuntimeContext
getDoubleCounter
in interface RuntimeContext
public <V,A extends Serializable> void addAccumulator(String name, Accumulator<V,A> accumulator)
RuntimeContext
addAccumulator
in interface RuntimeContext
public <V,A extends Serializable> Accumulator<V,A> getAccumulator(String name)
RuntimeContext
Throws an exception if the accumulator does not exist or if the accumulator exists, but with different type.
getAccumulator
in interface RuntimeContext
public ClassLoader getUserCodeClassLoader()
RuntimeContext
getUserCodeClassLoader
in interface RuntimeContext
public void registerUserCodeClassLoaderReleaseHookIfAbsent(String releaseHookName, Runnable releaseHook)
RuntimeContext
The release hook is executed just before the user code class loader is being released. Registration only happens if no hook has been registered under this name already.
registerUserCodeClassLoaderReleaseHookIfAbsent
in interface RuntimeContext
releaseHookName
- name of the release hook.releaseHook
- release hook which is executed just before the user code class loader is
being releasedpublic DistributedCache getDistributedCache()
RuntimeContext
DistributedCache
to get the local temporary file copies of files
otherwise not locally accessible.getDistributedCache
in interface RuntimeContext
public JobInfo getJobInfo()
RuntimeContext
getJobInfo
in interface RuntimeContext
public TaskInfo getTaskInfo()
RuntimeContext
getTaskInfo
in interface RuntimeContext
@PublicEvolving public <T> ValueState<T> getState(ValueStateDescriptor<T> stateProperties)
RuntimeContext
Because the scope of each value is the key of the currently processed element, and the elements are distributed by the Flink runtime, the system can transparently scale out and redistribute the state and KeyedStream.
The following code example shows how to implement a continuous counter that counts how many times elements of a certain key occur, and emits an updated count for that element on each occurrence.
DataStream<MyType> stream = ...;
KeyedStream<MyType> keyedStream = stream.keyBy("id");
keyedStream.map(new RichMapFunction<MyType, Tuple2<MyType, Long>>() {
private ValueState<Long> state;
public void open(Configuration cfg) {
state = getRuntimeContext().getState(
new ValueStateDescriptor<Long>("count", LongSerializer.INSTANCE, 0L));
}
public Tuple2<MyType, Long> map(MyType value) {
long count = state.value() + 1;
state.update(count);
return new Tuple2<>(value, count);
}
});
getState
in interface RuntimeContext
T
- The type of value stored in the state.stateProperties
- The descriptor defining the properties of the stats.@PublicEvolving public <T> ListState<T> getListState(ListStateDescriptor<T> stateProperties)
RuntimeContext
RuntimeContext.getState(ValueStateDescriptor)
, but is optimized for state that holds
lists. One can add elements to the list, or retrieve the list as a whole.
This state is only accessible if the function is executed on a KeyedStream.
DataStream<MyType> stream = ...;
KeyedStream<MyType> keyedStream = stream.keyBy("id");
keyedStream.map(new RichFlatMapFunction<MyType, List<MyType>>() {
private ListState<MyType> state;
public void open(Configuration cfg) {
state = getRuntimeContext().getListState(
new ListStateDescriptor<>("myState", MyType.class));
}
public void flatMap(MyType value, Collector<MyType> out) {
if (value.isDivider()) {
for (MyType t : state.get()) {
out.collect(t);
}
} else {
state.add(value);
}
}
});
getListState
in interface RuntimeContext
T
- The type of value stored in the state.stateProperties
- The descriptor defining the properties of the stats.@PublicEvolving public <T> ReducingState<T> getReducingState(ReducingStateDescriptor<T> stateProperties)
RuntimeContext
RuntimeContext.getState(ValueStateDescriptor)
, but is optimized for state that
aggregates values.
This state is only accessible if the function is executed on a KeyedStream.
DataStream<MyType> stream = ...;
KeyedStream<MyType> keyedStream = stream.keyBy("id");
keyedStream.map(new RichMapFunction<MyType, List<MyType>>() {
private ReducingState<Long> state;
public void open(Configuration cfg) {
state = getRuntimeContext().getReducingState(
new ReducingStateDescriptor<>("sum", (a, b) -> a + b, Long.class));
}
public Tuple2<MyType, Long> map(MyType value) {
state.add(value.count());
return new Tuple2<>(value, state.get());
}
});
getReducingState
in interface RuntimeContext
T
- The type of value stored in the state.stateProperties
- The descriptor defining the properties of the stats.@PublicEvolving public <IN,ACC,OUT> AggregatingState<IN,OUT> getAggregatingState(AggregatingStateDescriptor<IN,ACC,OUT> stateProperties)
RuntimeContext
RuntimeContext.getState(ValueStateDescriptor)
, but is optimized for state that
aggregates values with different types.
This state is only accessible if the function is executed on a KeyedStream.
DataStream<MyType> stream = ...;
KeyedStream<MyType> keyedStream = stream.keyBy("id");
AggregateFunction<...> aggregateFunction = ...
keyedStream.map(new RichMapFunction<MyType, List<MyType>>() {
private AggregatingState<MyType, Long> state;
public void open(Configuration cfg) {
state = getRuntimeContext().getAggregatingState(
new AggregatingStateDescriptor<>("sum", aggregateFunction, Long.class));
}
public Tuple2<MyType, Long> map(MyType value) {
state.add(value);
return new Tuple2<>(value, state.get());
}
});
getAggregatingState
in interface RuntimeContext
IN
- The type of the values that are added to the state.ACC
- The type of the accumulator (intermediate aggregation state).OUT
- The type of the values that are returned from the state.stateProperties
- The descriptor defining the properties of the stats.@PublicEvolving public <UK,UV> MapState<UK,UV> getMapState(MapStateDescriptor<UK,UV> stateProperties)
RuntimeContext
RuntimeContext.getState(ValueStateDescriptor)
, but is optimized for state that is
composed of user-defined key-value pairs
This state is only accessible if the function is executed on a KeyedStream.
DataStream<MyType> stream = ...;
KeyedStream<MyType> keyedStream = stream.keyBy("id");
keyedStream.map(new RichMapFunction<MyType, List<MyType>>() {
private MapState<MyType, Long> state;
public void open(Configuration cfg) {
state = getRuntimeContext().getMapState(
new MapStateDescriptor<>("sum", MyType.class, Long.class));
}
public Tuple2<MyType, Long> map(MyType value) {
return new Tuple2<>(value, state.get(value));
}
});
getMapState
in interface RuntimeContext
UK
- The type of the user keys stored in the state.UV
- The type of the user values stored in the state.stateProperties
- The descriptor defining the properties of the stats.@Internal @VisibleForTesting public String getAllocationIDAsString()
Copyright © 2014–2024 The Apache Software Foundation. All rights reserved.