Class PeriodicTrigger
java.lang.Object
org.springframework.scheduling.support.PeriodicTrigger
- All Implemented Interfaces:
- Trigger
A trigger for periodic task execution. The period may be applied as either
fixed-rate or fixed-delay, and an initial delay value may also be configured.
The default initial delay is 0, and the default behavior is fixed-delay
(i.e. the interval between successive executions is measured from each
completion time). To measure the interval between the
scheduled start time of each execution instead, set the
'fixedRate' property to 
true.
Note that the TaskScheduler interface already defines methods for scheduling tasks at fixed-rate or with fixed-delay. Both also support an optional value for the initial delay. Those methods should be used directly whenever possible. The value of this Trigger implementation is that it can be used within components that rely on the Trigger abstraction. For example, it may be convenient to allow periodic triggers, cron-based triggers, and even custom Trigger implementations to be used interchangeably.
- Since:
- 3.0
- Author:
- Mark Fisher
- 
Constructor SummaryConstructorsConstructorDescriptionPeriodicTrigger(long period) Deprecated.PeriodicTrigger(long period, @Nullable TimeUnit timeUnit) Deprecated.as of 6.0, in favor onPeriodicTrigger(Duration)PeriodicTrigger(Duration period) Create a trigger with the given period as a duration.
- 
Method SummaryModifier and TypeMethodDescriptionbooleanlongDeprecated.as of 6.0, in favor ongetInitialDelayDuration()Return the initial delay, ornullif none.longDeprecated.as of 6.0, in favor ongetPeriodDuration()Return this trigger's period.Deprecated.as of 6.0, with no direct replacementinthashCode()booleanReturn whether this trigger uses fixed rate (true) or fixed delay (false) behavior.nextExecution(TriggerContext triggerContext) Returns the time after which a task should run again.voidsetFixedRate(boolean fixedRate) Specify whether the periodic interval should be measured between the scheduled start times rather than between actual completion times.voidsetInitialDelay(long initialDelay) Deprecated.as of 6.0, in favor ofsetInitialDelay(Duration)voidsetInitialDelay(Duration initialDelay) Specify the delay for the initial execution.Methods inherited from class Objectclone, finalize, getClass, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface TriggernextExecutionTime
- 
Constructor Details- 
PeriodicTriggerDeprecated.as of 6.0, in favor onPeriodicTrigger(Duration)Create a trigger with the given period in milliseconds.
- 
PeriodicTriggerDeprecated.as of 6.0, in favor onPeriodicTrigger(Duration)Create a trigger with the given period and time unit. The time unit will apply not only to the period but also to any 'initialDelay' value, if configured on this Trigger later viasetInitialDelay(long).
- 
PeriodicTriggerCreate a trigger with the given period as a duration.- Since:
- 6.0
 
 
- 
- 
Method Details- 
getPeriod
- 
getPeriodDuration
- 
getTimeUnitDeprecated.as of 6.0, with no direct replacementReturn this trigger's time unit (milliseconds by default).- Since:
- 5.0.2
 
- 
setInitialDelayDeprecated.as of 6.0, in favor ofsetInitialDelay(Duration)Specify the delay for the initial execution. It will be evaluated in terms of this trigger'sTimeUnit. If no time unit was explicitly provided upon instantiation, the default is milliseconds.
- 
setInitialDelaySpecify the delay for the initial execution.- Since:
- 6.0
 
- 
getInitialDelayDeprecated.as of 6.0, in favor ongetInitialDelayDuration()Return the initial delay, or 0 if none.- Since:
- 5.0.2
 
- 
getInitialDelayDuration
- 
setFixedRatepublic void setFixedRate(boolean fixedRate) Specify whether the periodic interval should be measured between the scheduled start times rather than between actual completion times. The latter, "fixed delay" behavior, is the default.
- 
isFixedRatepublic boolean isFixedRate()Return whether this trigger uses fixed rate (true) or fixed delay (false) behavior.- Since:
- 5.0.2
 
- 
nextExecutionReturns the time after which a task should run again.- Specified by:
- nextExecutionin interface- Trigger
- Parameters:
- triggerContext- context object encapsulating last execution times and last completion time
- Returns:
- the next execution time as defined by the trigger,
or nullif the trigger won't fire anymore
 
- 
equals
- 
hashCode
 
- 
PeriodicTrigger(Duration)