Class OrderedScheduler
- java.lang.Object
- 
- org.apache.bookkeeper.common.util.OrderedExecutor
- 
- org.apache.bookkeeper.common.util.OrderedScheduler
 
 
- 
- All Implemented Interfaces:
- java.util.concurrent.Executor,- java.util.concurrent.ExecutorService,- java.util.concurrent.ScheduledExecutorService
 
 public class OrderedScheduler extends OrderedExecutor implements java.util.concurrent.ScheduledExecutorService This class provides supports submitting tasks with an ordering key, so that tasks submitted with the same key will always be executed in order, but tasks across different keys can be unordered. This retains parallelism while retaining the basic amount of ordering we want (e.g. , per ledger handle). Ordering is achieved by hashing the key objects to threads by theirObject.hashCode()method.
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description (package private) classOrderedScheduler.OrderedSchedulerDecoratedThreadstatic classOrderedScheduler.SchedulerBuilderBuilder to build ordered scheduler.- 
Nested classes/interfaces inherited from class org.apache.bookkeeper.common.util.OrderedExecutorOrderedExecutor.AbstractBuilder<T extends OrderedExecutor>, OrderedExecutor.Builder, OrderedExecutor.ContextPreservingCallable<T>, OrderedExecutor.ContextPreservingRunnable, OrderedExecutor.TimedCallable<T>, OrderedExecutor.TimedRunnable
 
- 
 - 
Field Summary- 
Fields inherited from class org.apache.bookkeeper.common.util.OrderedExecutorenableBusyWait, enableThreadScopedMetrics, maxTasksInQueue, name, NO_TASK_LIMIT, preserveMdcForTaskExecution, rand, taskExecutionStats, taskPendingStats, threadIds, threads, traceTaskExecution, WARN_TIME_MICRO_SEC_DEFAULT, warnTimeMicroSec
 
- 
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description protected com.google.common.util.concurrent.ListeningScheduledExecutorServiceaddExecutorDecorators(java.util.concurrent.ExecutorService executor)com.google.common.util.concurrent.ListeningScheduledExecutorServicechooseThread()com.google.common.util.concurrent.ListeningScheduledExecutorServicechooseThread(long orderingKey)skip hashcode generation in this special case.com.google.common.util.concurrent.ListeningScheduledExecutorServicechooseThread(java.lang.Object orderingKey)protected java.util.concurrent.ExecutorServicecreateSingleThreadExecutor(java.util.concurrent.ThreadFactory factory)protected com.google.common.util.concurrent.ListeningScheduledExecutorServicegetBoundedExecutor(java.util.concurrent.ExecutorService executor)static OrderedScheduler.SchedulerBuildernewSchedulerBuilder()Create a builder to build ordered scheduler.java.util.concurrent.ScheduledFuture<?>schedule(java.lang.Runnable command, long delay, java.util.concurrent.TimeUnit unit)<V> java.util.concurrent.ScheduledFuture<V>schedule(java.util.concurrent.Callable<V> callable, long delay, java.util.concurrent.TimeUnit unit)java.util.concurrent.ScheduledFuture<?>scheduleAtFixedRate(java.lang.Runnable command, long initialDelay, long period, java.util.concurrent.TimeUnit unit)java.util.concurrent.ScheduledFuture<?>scheduleAtFixedRateOrdered(java.lang.Object orderingKey, java.lang.Runnable command, long initialDelay, long period, java.util.concurrent.TimeUnit unit)Creates and executes a periodic action that becomes enabled first after the given initial delay, and subsequently with the given period.java.util.concurrent.ScheduledFuture<?>scheduleOrdered(java.lang.Object orderingKey, java.lang.Runnable command, long delay, java.util.concurrent.TimeUnit unit)Creates and executes a one-shot action that becomes enabled after the given delay.java.util.concurrent.ScheduledFuture<?>scheduleWithFixedDelay(java.lang.Runnable command, long initialDelay, long delay, java.util.concurrent.TimeUnit unit)java.util.concurrent.ScheduledFuture<?>scheduleWithFixedDelayOrdered(java.lang.Object orderingKey, java.lang.Runnable command, long initialDelay, long delay, java.util.concurrent.TimeUnit unit)Creates and executes a periodic action that becomes enabled first after the given initial delay, and subsequently with the given delay between the termination of one execution and the commencement of the next.<T> com.google.common.util.concurrent.ListenableFuture<T>submitOrdered(java.lang.Object orderingKey, java.util.concurrent.Callable<T> callable)schedules a one time action to execute with an ordering guarantee on the key.- 
Methods inherited from class org.apache.bookkeeper.common.util.OrderedExecutorawaitTermination, chooseThreadIdx, execute, executeOrdered, executeOrdered, executeOrdered, forceShutdown, getThreadID, invokeAll, invokeAll, invokeAny, invokeAny, isShutdown, isTerminated, newBuilder, preserveMdc, shutdown, shutdownNow, submit, submit, submit, submitOrdered, timedCallable, timedCallables, timedRunnable
 
- 
 
- 
- 
- 
Method Detail- 
newSchedulerBuilderpublic static OrderedScheduler.SchedulerBuilder newSchedulerBuilder() Create a builder to build ordered scheduler.- Returns:
- builder to build ordered scheduler.
 
 - 
createSingleThreadExecutorprotected java.util.concurrent.ExecutorService createSingleThreadExecutor(java.util.concurrent.ThreadFactory factory) - Overrides:
- createSingleThreadExecutorin class- OrderedExecutor
 
 - 
getBoundedExecutorprotected com.google.common.util.concurrent.ListeningScheduledExecutorService getBoundedExecutor(java.util.concurrent.ExecutorService executor) - Overrides:
- getBoundedExecutorin class- OrderedExecutor
 
 - 
addExecutorDecoratorsprotected com.google.common.util.concurrent.ListeningScheduledExecutorService addExecutorDecorators(java.util.concurrent.ExecutorService executor) - Overrides:
- addExecutorDecoratorsin class- OrderedExecutor
 
 - 
chooseThreadpublic com.google.common.util.concurrent.ListeningScheduledExecutorService chooseThread() - Overrides:
- chooseThreadin class- OrderedExecutor
 
 - 
chooseThreadpublic com.google.common.util.concurrent.ListeningScheduledExecutorService chooseThread(java.lang.Object orderingKey) - Overrides:
- chooseThreadin class- OrderedExecutor
 
 - 
chooseThreadpublic com.google.common.util.concurrent.ListeningScheduledExecutorService chooseThread(long orderingKey) Description copied from class:OrderedExecutorskip hashcode generation in this special case.- Overrides:
- chooseThreadin class- OrderedExecutor
- Parameters:
- orderingKey- long ordering key
- Returns:
- the thread for executing this order key
 
 - 
submitOrderedpublic <T> com.google.common.util.concurrent.ListenableFuture<T> submitOrdered(java.lang.Object orderingKey, java.util.concurrent.Callable<T> callable)schedules a one time action to execute with an ordering guarantee on the key.- Parameters:
- orderingKey-
- callable-
 
 - 
scheduleOrderedpublic java.util.concurrent.ScheduledFuture<?> scheduleOrdered(java.lang.Object orderingKey, java.lang.Runnable command, long delay, java.util.concurrent.TimeUnit unit)Creates and executes a one-shot action that becomes enabled after the given delay.- Parameters:
- orderingKey- - the key used for ordering
- command- - the Runnable to execute
- delay- - the time from now to delay execution
- unit- - the time unit of the delay parameter
- Returns:
- a ScheduledFuture representing pending completion of the task and whose get() method will return null upon completion
 
 - 
scheduleAtFixedRateOrderedpublic java.util.concurrent.ScheduledFuture<?> scheduleAtFixedRateOrdered(java.lang.Object orderingKey, java.lang.Runnable command, long initialDelay, long period, java.util.concurrent.TimeUnit unit)Creates and executes a periodic action that becomes enabled first after the given initial delay, and subsequently with the given period.For more details check ScheduledExecutorService.scheduleAtFixedRate(Runnable, long, long, TimeUnit).- Parameters:
- orderingKey- - the key used for ordering
- command- - the Runnable to execute
- initialDelay- - the time to delay first execution
- period- - the period between successive executions
- unit- - the time unit of the initialDelay and period parameters
- Returns:
- a ScheduledFuture representing pending completion of the task, and whose get() method will throw an exception upon cancellation
 
 - 
scheduleWithFixedDelayOrderedpublic java.util.concurrent.ScheduledFuture<?> scheduleWithFixedDelayOrdered(java.lang.Object orderingKey, java.lang.Runnable command, long initialDelay, long delay, java.util.concurrent.TimeUnit unit)Creates and executes a periodic action that becomes enabled first after the given initial delay, and subsequently with the given delay between the termination of one execution and the commencement of the next.For more details check ScheduledExecutorService.scheduleWithFixedDelay(Runnable, long, long, TimeUnit).- Parameters:
- orderingKey- - the key used for ordering
- command- - the Runnable to execute
- initialDelay- - the time to delay first execution
- delay- - the delay between the termination of one execution and the commencement of the next
- unit- - the time unit of the initialDelay and delay parameters
- Returns:
- a ScheduledFuture representing pending completion of the task, and whose get() method will throw an exception upon cancellation
 
 - 
schedulepublic java.util.concurrent.ScheduledFuture<?> schedule(java.lang.Runnable command, long delay, java.util.concurrent.TimeUnit unit)- Specified by:
- schedulein interface- java.util.concurrent.ScheduledExecutorService
 
 - 
schedulepublic <V> java.util.concurrent.ScheduledFuture<V> schedule(java.util.concurrent.Callable<V> callable, long delay, java.util.concurrent.TimeUnit unit)- Specified by:
- schedulein interface- java.util.concurrent.ScheduledExecutorService
 
 - 
scheduleAtFixedRatepublic java.util.concurrent.ScheduledFuture<?> scheduleAtFixedRate(java.lang.Runnable command, long initialDelay, long period, java.util.concurrent.TimeUnit unit)- Specified by:
- scheduleAtFixedRatein interface- java.util.concurrent.ScheduledExecutorService
 
 - 
scheduleWithFixedDelaypublic java.util.concurrent.ScheduledFuture<?> scheduleWithFixedDelay(java.lang.Runnable command, long initialDelay, long delay, java.util.concurrent.TimeUnit unit)- Specified by:
- scheduleWithFixedDelayin interface- java.util.concurrent.ScheduledExecutorService
 
 
- 
 
-