W
- The type of Windows
on which this trigger can operate.@PublicEvolving public class ContinuousProcessingTimeTrigger<W extends Window> extends Trigger<Object,W>
Trigger
that continuously fires based on a given time interval as measured by the clock
of the machine on which the job is running.Trigger.OnMergeContext, Trigger.TriggerContext
Modifier and Type | Method and Description |
---|---|
boolean |
canMerge()
Returns true if this trigger supports merging of trigger state and can therefore be used with
a
MergingWindowAssigner . |
void |
clear(W window,
Trigger.TriggerContext ctx)
Clears any state that the trigger might still hold for the given window.
|
long |
getInterval() |
static <W extends Window> |
of(Time interval)
Creates a trigger that continuously fires based on the given interval.
|
TriggerResult |
onElement(Object element,
long timestamp,
W window,
Trigger.TriggerContext ctx)
Called for every element that gets added to a pane.
|
TriggerResult |
onEventTime(long time,
W window,
Trigger.TriggerContext ctx)
Called when an event-time timer that was set using the trigger context fires.
|
void |
onMerge(W window,
Trigger.OnMergeContext ctx)
Called when several windows have been merged into one window by the
WindowAssigner . |
TriggerResult |
onProcessingTime(long time,
W window,
Trigger.TriggerContext ctx)
Called when a processing-time timer that was set using the trigger context fires.
|
String |
toString() |
public TriggerResult onElement(Object element, long timestamp, W window, Trigger.TriggerContext ctx) throws Exception
Trigger
onElement
in class Trigger<Object,W extends Window>
element
- The element that arrived.timestamp
- The timestamp of the element that arrived.window
- The window to which the element is being added.ctx
- A context object that can be used to register timer callbacks.Exception
public TriggerResult onEventTime(long time, W window, Trigger.TriggerContext ctx) throws Exception
Trigger
public TriggerResult onProcessingTime(long time, W window, Trigger.TriggerContext ctx) throws Exception
Trigger
public void clear(W window, Trigger.TriggerContext ctx) throws Exception
Trigger
Trigger.TriggerContext.registerEventTimeTimer(long)
and
Trigger.TriggerContext.registerProcessingTimeTimer(long)
should be deleted here as well as
state acquired using Trigger.TriggerContext.getPartitionedState(StateDescriptor)
.public boolean canMerge()
Trigger
MergingWindowAssigner
.
If this returns true
you must properly implement Trigger.onMerge(Window,
OnMergeContext)
public void onMerge(W window, Trigger.OnMergeContext ctx)
Trigger
WindowAssigner
.@VisibleForTesting public long getInterval()
public static <W extends Window> ContinuousProcessingTimeTrigger<W> of(Time interval)
W
- The type of Windows
on which this trigger can operate.interval
- The time interval at which to fire.Copyright © 2014–2021 The Apache Software Foundation. All rights reserved.