public final class SliceSharedWindowAggProcessor extends AbstractSliceWindowAggProcessor implements MergeCallback<Long,Iterable<Long>>
SliceSharedAssigner
, e.g.
hopping windows and cumulative windows.AbstractWindowAggProcessor.WindowIsEmptySupplier
WindowProcessor.Context<W>
sliceAssigner, windowBuffer, windowBufferFactory, windowInterval
accSerializer, aggregator, clockService, ctx, currentProgress, emptySupplier, genAggsHandler, isEventTime, reuseOutput, shiftTimeZone, useDayLightSaving, windowState, windowTimerService
Constructor and Description |
---|
SliceSharedWindowAggProcessor(GeneratedNamespaceAggsHandleFunction<Long> genAggsHandler,
WindowBuffer.Factory bufferFactory,
SliceSharedAssigner sliceAssigner,
TypeSerializer<RowData> accSerializer,
int indexOfCountStar,
ZoneId shiftTimeZone) |
Modifier and Type | Method and Description |
---|---|
void |
fireWindow(long timerTimestamp,
Long windowEnd)
Emit results of the given window.
|
void |
merge(Long mergeResult,
Iterable<Long> toBeMerged)
Specifies that states of the given windows or slices should be merged into the result window
or slice.
|
protected long |
sliceStateMergeTarget(long sliceToMerge)
Returns the slice state target to merge the given slice into when firing windows.
|
advanceProgress, clearWindow, close, createWindowSerializer, getWindowTimerService, open, prepareCheckpoint, processElement
collect, initializeWatermark
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
initializeWatermark
public SliceSharedWindowAggProcessor(GeneratedNamespaceAggsHandleFunction<Long> genAggsHandler, WindowBuffer.Factory bufferFactory, SliceSharedAssigner sliceAssigner, TypeSerializer<RowData> accSerializer, int indexOfCountStar, ZoneId shiftTimeZone)
public void fireWindow(long timerTimestamp, Long windowEnd) throws Exception
WindowProcessor
Note: the key context has been set.
fireWindow
in interface WindowProcessor<Long>
timerTimestamp
- the fired timestampwindowEnd
- the window to emitException
public void merge(@Nullable Long mergeResult, Iterable<Long> toBeMerged) throws Exception
MergeCallback
protected long sliceStateMergeTarget(long sliceToMerge) throws Exception
AbstractSliceWindowAggProcessor
sliceToMerge
. For shared windows, the merge target should be the shared slice
state.sliceStateMergeTarget
in class AbstractSliceWindowAggProcessor
Exception
SliceSharedAssigner.mergeSlices(long, MergeCallback)
Copyright © 2014–2024 The Apache Software Foundation. All rights reserved.