- java.lang.Object
-
- javafx.concurrent.Service<V>
-
- javafx.concurrent.ScheduledService<V>
-
- Type Parameters:
V
- The computed value of the ScheduledService
- All Implemented Interfaces:
Worker<V>
,EventTarget
public abstract class ScheduledService<V> extends Service<V>
The ScheduledService is a
Service
which will automatically restart itself after a successful execution, and under some conditions will restart even in case of failure. A new ScheduledService begins in the READY state, just as a normal Service. After callingstart
orrestart
, the ScheduledService will enter the SCHEDULED state for the duration specified bydelay
.Once RUNNING, the ScheduledService will execute its Task. On successful completion, the ScheduledService will transition to the SUCCEEDED state, and then to the READY state and back to the SCHEDULED state. The amount of time the ScheduledService will remain in this state depends on the amount of time between the last state transition to RUNNING, and the current time, and the
period
. In short, theperiod
defines the minimum amount of time from the start of one run and the start of the next. If the previous execution completed beforeperiod
expires, then the ScheduledService will remain in the SCHEDULED state until the period expires. If on the other hand the execution took longer than the specified period, then the ScheduledService will immediately transition back to RUNNING.If, while RUNNING, the ScheduledService's Task throws an error or in some other way ends up transitioning to FAILED, then the ScheduledService will either restart or quit, depending on the values for
backoffStrategy
,restartOnFailure
, andmaximumFailureCount
.If a failure occurs and
restartOnFailure
is false, then the ScheduledService will transition to FAILED and will stop. To restart a failed ScheduledService, you must call restart manually.If a failure occurs and
restartOnFailure
is true, then the the ScheduledService may restart automatically. First, the result of callingbackoffStrategy
will become the newcumulativePeriod
. In this way, after each failure, you can cause the service to wait a longer and longer period of time before restarting. Once the task completes successfully, the cumulativePeriod is reset to the value ofperiod
.ScheduledService defines static EXPONENTIAL_BACKOFF_STRATEGY and LOGARITHMIC_BACKOFF_STRATEGY implementations, of which LOGARITHMIC_BACKOFF_STRATEGY is the default value for backoffStrategy. After
maximumFailureCount
is reached, the ScheduledService will transition to FAILED in exactly the same way as ifrestartOnFailure
were false.If the
The ScheduledService is typically used for use cases that involve polling. For example, you may want to ping a server on a regular basis to see if there are any updates. Such as ScheduledService might be implemented like this:period
ordelay
is changed while the ScheduledService is running, the new values will be taken into account on the next iteration. For example, if theperiod
is increased, then the next time the ScheduledService enters the SCHEDULED state, the newperiod
will be used. Likewise, if thedelay
is changed, the new value will be honored on the next restart or reset/start.
This example will ping the remote server every 1 second.ScheduledService<Document> svc = new ScheduledService<Document>() { protected Task<Document> createTask() { return new Task<Document>() { protected Document call() { // Connect to a Server // Get the XML document // Parse it into a document return document; } }; } }; svc.setPeriod(Duration.seconds(1));
Timing for this class is not absolutely reliable. A very busy event thread might introduce some timing lag into the beginning of the execution of the background Task, so very small values for the period or delay are likely to be inaccurate. A delay or period in the hundreds of milliseconds or larger should be fairly reliable.
The ScheduledService in its default configuration has a default
period
of 0 and a defaultdelay
of 0. This will cause the ScheduledService to execute the task immediately uponService.start()
, and re-executing immediately upon successful completion.For this purposes of this class, any Duration that answers true to
Duration.isUnknown()
will treat that duration as if it were Duration.ZERO. Likewise, any Duration which answers true toDuration.isIndefinite()
will be treated as if it were a duration of Double.MAX_VALUE milliseconds. Any null Duration is treated as Duration.ZERO. Any custom implementation of an backoff strategy callback must be prepared to handle these different potential values.The ScheduledService introduces a new property called
Implementer Note: ThelastValue
. The lastValue is the value that was last successfully computed. Because a Service clears itsvalue
property on each run, and because the ScheduledService will reschedule a run immediately after completion (unless it enters the cancelled or failed states), the value property is not overly useful on a ScheduledService. In most cases you will want to instead use the value returned by lastValue.Service.ready()
,Service.scheduled()
,Service.running()
,succeeded()
,Service.cancelled()
, andfailed()
methods are implemented in this class. Subclasses which also override these methods must take care to invoke the super implementation.- Since:
- JavaFX 8.0
-
-
Property Summary
Properties Type Property Description ObjectProperty<Callback<ScheduledService<?>,Duration>>
backoffStrategy
Computes the amount of time to add to the period on each failure.ReadOnlyObjectProperty<Duration>
cumulativePeriod
The current cumulative period in use between iterations.ReadOnlyIntegerProperty
currentFailureCount
The current number of times the ScheduledService has failed.ObjectProperty<Duration>
delay
The initial delay between when the ScheduledService is first started, and when it will begin operation.ReadOnlyObjectProperty<V>
lastValue
The last successfully computed value.ObjectProperty<Duration>
maximumCumulativePeriod
The maximum allowed value for the cumulativePeriod.IntegerProperty
maximumFailureCount
The maximum number of times the ScheduledService can fail before it simply ends in the FAILED state.ObjectProperty<Duration>
period
The minimum amount of time to allow between the start of the last run and the start of the next run.BooleanProperty
restartOnFailure
Indicates whether the ScheduledService should automatically restart in the case of a failure in the Task.
-
Nested Class Summary
-
Nested classes/interfaces inherited from interface javafx.concurrent.Worker
Worker.State
-
-
Field Summary
Fields Modifier and Type Field Description static Callback<ScheduledService<?>,Duration>
EXPONENTIAL_BACKOFF_STRATEGY
A Callback implementation for thebackoffStrategy
property which will exponentially backoff the period between re-executions in the case of a failure.static Callback<ScheduledService<?>,Duration>
LINEAR_BACKOFF_STRATEGY
A Callback implementation for thebackoffStrategy
property which will linearly backoff the period between re-executions in the case of a failure.static Callback<ScheduledService<?>,Duration>
LOGARITHMIC_BACKOFF_STRATEGY
A Callback implementation for thebackoffStrategy
property which will logarithmically backoff the period between re-executions in the case of a failure.
-
Constructor Summary
Constructors Constructor Description ScheduledService()
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description ObjectProperty<Callback<ScheduledService<?>,Duration>>
backoffStrategyProperty()
Computes the amount of time to add to the period on each failure.boolean
cancel()
Cancels any currently running task and stops this scheduled service, such that no additional iterations will occur.ReadOnlyObjectProperty<Duration>
cumulativePeriodProperty()
The current cumulative period in use between iterations.ReadOnlyIntegerProperty
currentFailureCountProperty()
The current number of times the ScheduledService has failed.ObjectProperty<Duration>
delayProperty()
The initial delay between when the ScheduledService is first started, and when it will begin operation.protected void
executeTask(Task<V> task)
Uses theexecutor
defined on this Service to execute the given task.protected void
failed()
A protected convenience method for subclasses, called whenever the state of the Service has transitioned to the FAILED state.Callback<ScheduledService<?>,Duration>
getBackoffStrategy()
Gets the value of the property backoffStrategy.Duration
getCumulativePeriod()
Gets the value of the property cumulativePeriod.int
getCurrentFailureCount()
Gets the value of the property currentFailureCount.Duration
getDelay()
Gets the value of the property delay.V
getLastValue()
Gets the value of the property lastValue.Duration
getMaximumCumulativePeriod()
Gets the value of the property maximumCumulativePeriod.int
getMaximumFailureCount()
Gets the value of the property maximumFailureCount.Duration
getPeriod()
Gets the value of the property period.boolean
getRestartOnFailure()
Gets the value of the property restartOnFailure.ReadOnlyObjectProperty<V>
lastValueProperty()
The last successfully computed value.ObjectProperty<Duration>
maximumCumulativePeriodProperty()
The maximum allowed value for the cumulativePeriod.IntegerProperty
maximumFailureCountProperty()
The maximum number of times the ScheduledService can fail before it simply ends in the FAILED state.ObjectProperty<Duration>
periodProperty()
The minimum amount of time to allow between the start of the last run and the start of the next run.void
reset()
Resets the Service.BooleanProperty
restartOnFailureProperty()
Indicates whether the ScheduledService should automatically restart in the case of a failure in the Task.void
setBackoffStrategy(Callback<ScheduledService<?>,Duration> value)
Sets the value of the property backoffStrategy.void
setDelay(Duration value)
Sets the value of the property delay.void
setMaximumCumulativePeriod(Duration value)
Sets the value of the property maximumCumulativePeriod.void
setMaximumFailureCount(int value)
Sets the value of the property maximumFailureCount.void
setPeriod(Duration value)
Sets the value of the property period.void
setRestartOnFailure(boolean value)
Sets the value of the property restartOnFailure.protected void
succeeded()
A protected convenience method for subclasses, called whenever the state of the Service has transitioned to the SUCCEEDED state.-
Methods inherited from class javafx.concurrent.Service
addEventFilter, addEventHandler, buildEventDispatchChain, cancelled, createTask, exceptionProperty, executorProperty, fireEvent, getException, getExecutor, getMessage, getOnCancelled, getOnFailed, getOnReady, getOnRunning, getOnScheduled, getOnSucceeded, getProgress, getState, getTitle, getTotalWork, getValue, getWorkDone, isRunning, messageProperty, onCancelledProperty, onFailedProperty, onReadyProperty, onRunningProperty, onScheduledProperty, onSucceededProperty, progressProperty, ready, removeEventFilter, removeEventHandler, restart, running, runningProperty, scheduled, setEventHandler, setExecutor, setOnCancelled, setOnFailed, setOnReady, setOnRunning, setOnScheduled, setOnSucceeded, start, stateProperty, titleProperty, totalWorkProperty, valueProperty, workDoneProperty
-
-
-
-
Property Detail
-
delay
public final ObjectProperty<Duration> delayProperty
The initial delay between when the ScheduledService is first started, and when it will begin operation. This is the amount of time the ScheduledService will remain in the SCHEDULED state, before entering the RUNNING state, following a fresh invocation ofService.start()
orService.restart()
.- See Also:
getDelay()
,setDelay(Duration)
-
period
public final ObjectProperty<Duration> periodProperty
The minimum amount of time to allow between the start of the last run and the start of the next run. The actual period (also known ascumulativePeriod
) will depend on this property as well as thebackoffStrategy
and number of failures.- See Also:
getPeriod()
,setPeriod(Duration)
-
backoffStrategy
public final ObjectProperty<Callback<ScheduledService<?>,Duration>> backoffStrategyProperty
Computes the amount of time to add to the period on each failure. This cumulative amount is reset whenever the the ScheduledService is manually restarted.- See Also:
getBackoffStrategy()
,setBackoffStrategy(Callback)
-
restartOnFailure
public final BooleanProperty restartOnFailureProperty
Indicates whether the ScheduledService should automatically restart in the case of a failure in the Task.
-
maximumFailureCount
public final IntegerProperty maximumFailureCountProperty
The maximum number of times the ScheduledService can fail before it simply ends in the FAILED state. You can of course restart the ScheduledService manually, which will cause the current count to be reset.
-
currentFailureCount
public final ReadOnlyIntegerProperty currentFailureCountProperty
The current number of times the ScheduledService has failed. This is reset whenever the ScheduledService is manually restarted.- See Also:
getCurrentFailureCount()
-
cumulativePeriod
public final ReadOnlyObjectProperty<Duration> cumulativePeriodProperty
The current cumulative period in use between iterations. This will be the same asperiod
, except after a failure, in which case the result of the backoffStrategy will be used as the cumulative period following each failure. This is reset whenever the ScheduledService is manually restarted or an iteration is successful. The cumulativePeriod is modified when the ScheduledService enters the scheduled state. The cumulativePeriod can be capped by setting themaximumCumulativePeriod
.- See Also:
getCumulativePeriod()
-
maximumCumulativePeriod
public final ObjectProperty<Duration> maximumCumulativePeriodProperty
The maximum allowed value for the cumulativePeriod. Setting this value will help ensure that in the case of repeated failures the back-off algorithm doesn't end up producing unreasonably large values for cumulative period. The cumulative period is guaranteed not to be any larger than this value. If the maximumCumulativePeriod is negative, then cumulativePeriod will be capped at 0. If maximumCumulativePeriod is NaN or null, then it will not influence the cumulativePeriod.
-
lastValue
public final ReadOnlyObjectProperty<V> lastValueProperty
The last successfully computed value. During each iteration, the "value" of the ScheduledService will be reset to null, as with any other Service. The "lastValue" however will be set to the most recently successfully computed value, even across iterations. It is reset however whenever you manually call reset or restart.- See Also:
getLastValue()
-
-
Field Detail
-
EXPONENTIAL_BACKOFF_STRATEGY
public static final Callback<ScheduledService<?>,Duration> EXPONENTIAL_BACKOFF_STRATEGY
A Callback implementation for thebackoffStrategy
property which will exponentially backoff the period between re-executions in the case of a failure. This computation takes the original period and the number of consecutive failures and computes the backoff amount from that information.If the
service
is null, then Duration.ZERO is returned. If the period is 0 then the result of this method will simply beMath.exp(currentFailureCount)
. In all other cases, the returned value is the same asperiod + (period * Math.exp(currentFailureCount))
.
-
LOGARITHMIC_BACKOFF_STRATEGY
public static final Callback<ScheduledService<?>,Duration> LOGARITHMIC_BACKOFF_STRATEGY
A Callback implementation for thebackoffStrategy
property which will logarithmically backoff the period between re-executions in the case of a failure. This computation takes the original period and the number of consecutive failures and computes the backoff amount from that information.If the
service
is null, then Duration.ZERO is returned. If the period is 0 then the result of this method will simply beMath.log1p(currentFailureCount)
. In all other cases, the returned value is the same asperiod + (period * Math.log1p(currentFailureCount))
.
-
LINEAR_BACKOFF_STRATEGY
public static final Callback<ScheduledService<?>,Duration> LINEAR_BACKOFF_STRATEGY
A Callback implementation for thebackoffStrategy
property which will linearly backoff the period between re-executions in the case of a failure. This computation takes the original period and the number of consecutive failures and computes the backoff amount from that information.If the
service
is null, then Duration.ZERO is returned. If the period is 0 then the result of this method will simply becurrentFailureCount
. In all other cases, the returned value is the same asperiod + (period * currentFailureCount)
.
-
-
Method Detail
-
getDelay
public final Duration getDelay()
Gets the value of the property delay.- Property description:
- The initial delay between when the ScheduledService is first started, and when it will begin
operation. This is the amount of time the ScheduledService will remain in the SCHEDULED state,
before entering the RUNNING state, following a fresh invocation of
Service.start()
orService.restart()
.
-
setDelay
public final void setDelay(Duration value)
Sets the value of the property delay.- Property description:
- The initial delay between when the ScheduledService is first started, and when it will begin
operation. This is the amount of time the ScheduledService will remain in the SCHEDULED state,
before entering the RUNNING state, following a fresh invocation of
Service.start()
orService.restart()
.
-
delayProperty
public final ObjectProperty<Duration> delayProperty()
The initial delay between when the ScheduledService is first started, and when it will begin operation. This is the amount of time the ScheduledService will remain in the SCHEDULED state, before entering the RUNNING state, following a fresh invocation ofService.start()
orService.restart()
.- See Also:
getDelay()
,setDelay(Duration)
-
getPeriod
public final Duration getPeriod()
Gets the value of the property period.- Property description:
- The minimum amount of time to allow between the start of the last run and the start of the next run.
The actual period (also known as
cumulativePeriod
) will depend on this property as well as thebackoffStrategy
and number of failures.
-
setPeriod
public final void setPeriod(Duration value)
Sets the value of the property period.- Property description:
- The minimum amount of time to allow between the start of the last run and the start of the next run.
The actual period (also known as
cumulativePeriod
) will depend on this property as well as thebackoffStrategy
and number of failures.
-
periodProperty
public final ObjectProperty<Duration> periodProperty()
The minimum amount of time to allow between the start of the last run and the start of the next run. The actual period (also known ascumulativePeriod
) will depend on this property as well as thebackoffStrategy
and number of failures.- See Also:
getPeriod()
,setPeriod(Duration)
-
getBackoffStrategy
public final Callback<ScheduledService<?>,Duration> getBackoffStrategy()
Gets the value of the property backoffStrategy.- Property description:
- Computes the amount of time to add to the period on each failure. This cumulative amount is reset whenever the the ScheduledService is manually restarted.
-
setBackoffStrategy
public final void setBackoffStrategy(Callback<ScheduledService<?>,Duration> value)
Sets the value of the property backoffStrategy.- Property description:
- Computes the amount of time to add to the period on each failure. This cumulative amount is reset whenever the the ScheduledService is manually restarted.
-
backoffStrategyProperty
public final ObjectProperty<Callback<ScheduledService<?>,Duration>> backoffStrategyProperty()
Computes the amount of time to add to the period on each failure. This cumulative amount is reset whenever the the ScheduledService is manually restarted.- See Also:
getBackoffStrategy()
,setBackoffStrategy(Callback)
-
getRestartOnFailure
public final boolean getRestartOnFailure()
Gets the value of the property restartOnFailure.- Property description:
- Indicates whether the ScheduledService should automatically restart in the case of a failure in the Task.
-
setRestartOnFailure
public final void setRestartOnFailure(boolean value)
Sets the value of the property restartOnFailure.- Property description:
- Indicates whether the ScheduledService should automatically restart in the case of a failure in the Task.
-
restartOnFailureProperty
public final BooleanProperty restartOnFailureProperty()
Indicates whether the ScheduledService should automatically restart in the case of a failure in the Task.
-
getMaximumFailureCount
public final int getMaximumFailureCount()
Gets the value of the property maximumFailureCount.- Property description:
- The maximum number of times the ScheduledService can fail before it simply ends in the FAILED state. You can of course restart the ScheduledService manually, which will cause the current count to be reset.
-
setMaximumFailureCount
public final void setMaximumFailureCount(int value)
Sets the value of the property maximumFailureCount.- Property description:
- The maximum number of times the ScheduledService can fail before it simply ends in the FAILED state. You can of course restart the ScheduledService manually, which will cause the current count to be reset.
-
maximumFailureCountProperty
public final IntegerProperty maximumFailureCountProperty()
The maximum number of times the ScheduledService can fail before it simply ends in the FAILED state. You can of course restart the ScheduledService manually, which will cause the current count to be reset.
-
getCurrentFailureCount
public final int getCurrentFailureCount()
Gets the value of the property currentFailureCount.- Property description:
- The current number of times the ScheduledService has failed. This is reset whenever the ScheduledService is manually restarted.
-
currentFailureCountProperty
public final ReadOnlyIntegerProperty currentFailureCountProperty()
The current number of times the ScheduledService has failed. This is reset whenever the ScheduledService is manually restarted.- See Also:
getCurrentFailureCount()
-
getCumulativePeriod
public final Duration getCumulativePeriod()
Gets the value of the property cumulativePeriod.- Property description:
- The current cumulative period in use between iterations. This will be the same as
period
, except after a failure, in which case the result of the backoffStrategy will be used as the cumulative period following each failure. This is reset whenever the ScheduledService is manually restarted or an iteration is successful. The cumulativePeriod is modified when the ScheduledService enters the scheduled state. The cumulativePeriod can be capped by setting themaximumCumulativePeriod
.
-
cumulativePeriodProperty
public final ReadOnlyObjectProperty<Duration> cumulativePeriodProperty()
The current cumulative period in use between iterations. This will be the same asperiod
, except after a failure, in which case the result of the backoffStrategy will be used as the cumulative period following each failure. This is reset whenever the ScheduledService is manually restarted or an iteration is successful. The cumulativePeriod is modified when the ScheduledService enters the scheduled state. The cumulativePeriod can be capped by setting themaximumCumulativePeriod
.- See Also:
getCumulativePeriod()
-
getMaximumCumulativePeriod
public final Duration getMaximumCumulativePeriod()
Gets the value of the property maximumCumulativePeriod.- Property description:
- The maximum allowed value for the cumulativePeriod. Setting this value will help ensure that in the case of repeated failures the back-off algorithm doesn't end up producing unreasonably large values for cumulative period. The cumulative period is guaranteed not to be any larger than this value. If the maximumCumulativePeriod is negative, then cumulativePeriod will be capped at 0. If maximumCumulativePeriod is NaN or null, then it will not influence the cumulativePeriod.
-
setMaximumCumulativePeriod
public final void setMaximumCumulativePeriod(Duration value)
Sets the value of the property maximumCumulativePeriod.- Property description:
- The maximum allowed value for the cumulativePeriod. Setting this value will help ensure that in the case of repeated failures the back-off algorithm doesn't end up producing unreasonably large values for cumulative period. The cumulative period is guaranteed not to be any larger than this value. If the maximumCumulativePeriod is negative, then cumulativePeriod will be capped at 0. If maximumCumulativePeriod is NaN or null, then it will not influence the cumulativePeriod.
-
maximumCumulativePeriodProperty
public final ObjectProperty<Duration> maximumCumulativePeriodProperty()
The maximum allowed value for the cumulativePeriod. Setting this value will help ensure that in the case of repeated failures the back-off algorithm doesn't end up producing unreasonably large values for cumulative period. The cumulative period is guaranteed not to be any larger than this value. If the maximumCumulativePeriod is negative, then cumulativePeriod will be capped at 0. If maximumCumulativePeriod is NaN or null, then it will not influence the cumulativePeriod.
-
getLastValue
public final V getLastValue()
Gets the value of the property lastValue.- Property description:
- The last successfully computed value. During each iteration, the "value" of the ScheduledService will be reset to null, as with any other Service. The "lastValue" however will be set to the most recently successfully computed value, even across iterations. It is reset however whenever you manually call reset or restart.
-
lastValueProperty
public final ReadOnlyObjectProperty<V> lastValueProperty()
The last successfully computed value. During each iteration, the "value" of the ScheduledService will be reset to null, as with any other Service. The "lastValue" however will be set to the most recently successfully computed value, even across iterations. It is reset however whenever you manually call reset or restart.- See Also:
getLastValue()
-
executeTask
protected void executeTask(Task<V> task)
Description copied from class:Service
Uses the
executor
defined on this Service to execute the given task. If theexecutor
is null, then a default executor is used which will create a new daemon thread on which to execute this task.This method is intended only to be called by the Service implementation.
- Overrides:
executeTask
in classService<V>
- Parameters:
task
- a non-null task to execute
-
succeeded
protected void succeeded()
A protected convenience method for subclasses, called whenever the state of the Service has transitioned to the SUCCEEDED state. This method is invoked after the Service has been fully transitioned to the new state. Implementation Note: Subclasses which override this method must call this super implementation.
-
failed
protected void failed()
A protected convenience method for subclasses, called whenever the state of the Service has transitioned to the FAILED state. This method is invoked after the Service has been fully transitioned to the new state. Implementation Note: Subclasses which override this method must call this super implementation.
-
reset
public void reset()
Resets the Service. May only be called while in one of the finish states, that is, SUCCEEDED, FAILED, or CANCELLED, or when READY. This method should only be called on the FX application thread. Implementation Note: Subclasses which override this method must call this super implementation.
-
cancel
public boolean cancel()
Cancels any currently running task and stops this scheduled service, such that no additional iterations will occur.
-
-