Package sonia.scm.repository.spi
Interface SyncAsyncExecutorProvider
public interface SyncAsyncExecutorProvider
Use this provider to get 
SyncAsyncExecutor instances to execute a number of normally short-lived tasks, that
 should be run asynchronously (or even be skipped) whenever they take too long in summary.
 
 The goal of this is a "best effort" approach: The submitted tasks are run immediately when they are submitted, unless
 a given timespan (switchToAsyncInSeconds) has passed. From this moment on the tasks are put into a queue to be
 processed asynchronously. If even then they take too long and their accumulated asynchronous runtime exceeds another
 limit (maxAsyncAbortSeconds), the tasks are skipped.
 
Note that whenever a task has been started either synchronously or asynchronously it will neither be terminated nor switched from foreground to background execution, so this will only work well for short-living tasks. A long running task can still block this for longer than the configured amount of seconds.
- 
Field SummaryFields
- 
Method SummaryModifier and TypeMethodDescriptiondefault SyncAsyncExecutorCreates anSyncAsyncExecutorthat will run tasks synchronously forDEFAULT_SWITCH_TO_ASYNC_IN_SECONDSseconds.createExecutorWithSecondsToTimeout(int switchToAsyncInSeconds) Creates anSyncAsyncExecutorthat will run tasks synchronously forswitchToAsyncInSecondsseconds.createExecutorWithSecondsToTimeout(int switchToAsyncInSeconds, int maxAsyncAbortSeconds) Creates anSyncAsyncExecutorthat will run tasks synchronously forswitchToAsyncInSecondsseconds and will abort tasks after they ranmaxAsyncAbortSecondsasynchronously.
- 
Field Details- 
DEFAULT_SWITCH_TO_ASYNC_IN_SECONDSstatic final int DEFAULT_SWITCH_TO_ASYNC_IN_SECONDS- See Also:
 
 
- 
- 
Method Details- 
createExecutorWithDefaultTimeoutCreates anSyncAsyncExecutorthat will run tasks synchronously forDEFAULT_SWITCH_TO_ASYNC_IN_SECONDSseconds. The limit of asynchronous runtime is implementation dependant.- Returns:
- The executor.
 
- 
createExecutorWithSecondsToTimeoutCreates anSyncAsyncExecutorthat will run tasks synchronously forswitchToAsyncInSecondsseconds. The limit of asynchronous runtime is implementation dependant.- Parameters:
- switchToAsyncInSeconds- The amount of seconds submitted tasks will be run synchronously. After this time, further tasks will be run asynchronously. To run all tasks asynchronously no matter what, set this to- 0.
- Returns:
- The executor.
 
- 
createExecutorWithSecondsToTimeoutSyncAsyncExecutor createExecutorWithSecondsToTimeout(int switchToAsyncInSeconds, int maxAsyncAbortSeconds) Creates anSyncAsyncExecutorthat will run tasks synchronously forswitchToAsyncInSecondsseconds and will abort tasks after they ranmaxAsyncAbortSecondsasynchronously.- Parameters:
- switchToAsyncInSeconds- The amount of seconds submitted tasks will be run synchronously. After this time, further tasks will be run asynchronously. To run all tasks asynchronously no matter what, set this to- 0.
- maxAsyncAbortSeconds- The amount of seconds, tasks that were started asynchronously may run in summary before remaining tasks will not be executed at all anymore. To abort all tasks that are submitted after- switchToAsyncInSecondsimmediately, set this to- 0.
- Returns:
- The executor.
 
 
-