Class OrderedThreadPoolExecutor
java.lang.Object
java.util.concurrent.AbstractExecutorService
java.util.concurrent.ThreadPoolExecutor
org.apache.mina.filter.executor.OrderedThreadPoolExecutor
- All Implemented Interfaces:
Executor, ExecutorService
A
ThreadPoolExecutor that maintains the order of IoEvents.
If you don't need to maintain the order of events per session, please use
UnorderedThreadPoolExecutor.
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionprivate classA class used to store the ordered list of events to be processed by the session, and the current task state.private classNested classes/interfaces inherited from class ThreadPoolExecutor
ThreadPoolExecutor.AbortPolicy, ThreadPoolExecutor.CallerRunsPolicy, ThreadPoolExecutor.DiscardOldestPolicy, ThreadPoolExecutor.DiscardPolicy -
Field Summary
FieldsModifier and TypeFieldDescriptionprivate longprivate static final intA default value for the initial pool sizeprivate static final intA default value for the KeepAlive delayprivate static final intA default value for the maximum pool sizeprivate final IoEventQueueHandlerprivate static final IoSessionprivate final AtomicIntegerprivate intprivate static final org.slf4j.LoggerA logger for this class (commented as it breaks MDCFlter tests)private booleanprivate static final AttributeKeyA key stored into the session's attribute for the event tasks being queuedprivate final BlockingQueue<IoSession> A queue used to store the available sessionsprivate final Set<OrderedThreadPoolExecutor.Worker> -
Constructor Summary
ConstructorsConstructorDescriptionCreates a default ThreadPool, with default values : - minimum pool size is 0 - maximum pool size is 16 - keepAlive set to 30 seconds - A default ThreadFactory - All events are acceptedOrderedThreadPoolExecutor(int maximumPoolSize) Creates a default ThreadPool, with default values : - minimum pool size is 0 - keepAlive set to 30 seconds - A default ThreadFactory - All events are acceptedOrderedThreadPoolExecutor(int corePoolSize, int maximumPoolSize) Creates a default ThreadPool, with default values : - keepAlive set to 30 seconds - A default ThreadFactory - All events are acceptedOrderedThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit) Creates a default ThreadPool, with default values : - A default ThreadFactory - All events are acceptedOrderedThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, ThreadFactory threadFactory) Creates a default ThreadPool, with default values : - A default ThreadFactoryOrderedThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, ThreadFactory threadFactory, IoEventQueueHandler eventQueueHandler) Creates a new instance of a OrderedThreadPoolExecutor.OrderedThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, IoEventQueueHandler eventQueueHandler) Creates a default ThreadPool, with default values : - A default ThreadFactory -
Method Summary
Modifier and TypeMethodDescriptionprivate voidAdd a new thread to execute a task, if needed and possible.private voidAdd a new Worker only if there are no idle worker.booleanawaitTermination(long timeout, TimeUnit unit) private voidcheckTaskType(Runnable task) voidintlongintintgetQueue()getSessionTasksQueue(IoSession session) Get the session's tasks queue.longbooleanbooleanbooleanintbooleanprivate voidA Helper class used to print the list of events being queued.voidpurge()private voidrejectTask(Runnable task) booleanprivate voidvoidsetCorePoolSize(int corePoolSize) voidsetMaximumPoolSize(int maximumPoolSize) voidvoidshutdown()Methods inherited from class ThreadPoolExecutor
afterExecute, allowCoreThreadTimeOut, allowsCoreThreadTimeOut, beforeExecute, finalize, getCorePoolSize, getKeepAliveTime, getMaximumPoolSize, getRejectedExecutionHandler, getThreadFactory, setKeepAliveTime, setThreadFactory, terminated, toStringMethods inherited from class AbstractExecutorService
invokeAll, invokeAll, invokeAny, invokeAny, newTaskFor, newTaskFor, submit, submit, submit
-
Field Details
-
LOGGER
private static final org.slf4j.Logger LOGGERA logger for this class (commented as it breaks MDCFlter tests) -
DEFAULT_INITIAL_THREAD_POOL_SIZE
private static final int DEFAULT_INITIAL_THREAD_POOL_SIZEA default value for the initial pool size- See Also:
-
DEFAULT_MAX_THREAD_POOL
private static final int DEFAULT_MAX_THREAD_POOLA default value for the maximum pool size- See Also:
-
DEFAULT_KEEP_ALIVE
private static final int DEFAULT_KEEP_ALIVEA default value for the KeepAlive delay- See Also:
-
EXIT_SIGNAL
-
TASKS_QUEUE
A key stored into the session's attribute for the event tasks being queued -
waitingSessions
A queue used to store the available sessions -
workers
-
largestPoolSize
private volatile int largestPoolSize -
idleWorkers
-
completedTaskCount
private long completedTaskCount -
shutdown
private volatile boolean shutdown -
eventQueueHandler
-
-
Constructor Details
-
OrderedThreadPoolExecutor
public OrderedThreadPoolExecutor()Creates a default ThreadPool, with default values : - minimum pool size is 0 - maximum pool size is 16 - keepAlive set to 30 seconds - A default ThreadFactory - All events are accepted -
OrderedThreadPoolExecutor
public OrderedThreadPoolExecutor(int maximumPoolSize) Creates a default ThreadPool, with default values : - minimum pool size is 0 - keepAlive set to 30 seconds - A default ThreadFactory - All events are accepted- Parameters:
maximumPoolSize- The maximum pool size
-
OrderedThreadPoolExecutor
public OrderedThreadPoolExecutor(int corePoolSize, int maximumPoolSize) Creates a default ThreadPool, with default values : - keepAlive set to 30 seconds - A default ThreadFactory - All events are accepted- Parameters:
corePoolSize- The initial pool sizePoolSizemaximumPoolSize- The maximum pool size
-
OrderedThreadPoolExecutor
public OrderedThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit) Creates a default ThreadPool, with default values : - A default ThreadFactory - All events are accepted- Parameters:
corePoolSize- The initial pool sizePoolSizemaximumPoolSize- The maximum pool sizekeepAliveTime- Default duration for a threadunit- Time unit used for the keepAlive value
-
OrderedThreadPoolExecutor
public OrderedThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, IoEventQueueHandler eventQueueHandler) Creates a default ThreadPool, with default values : - A default ThreadFactory- Parameters:
corePoolSize- The initial pool sizePoolSizemaximumPoolSize- The maximum pool sizekeepAliveTime- Default duration for a threadunit- Time unit used for the keepAlive valueeventQueueHandler- The queue used to store events
-
OrderedThreadPoolExecutor
public OrderedThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, ThreadFactory threadFactory) Creates a default ThreadPool, with default values : - A default ThreadFactory- Parameters:
corePoolSize- The initial pool sizePoolSizemaximumPoolSize- The maximum pool sizekeepAliveTime- Default duration for a threadunit- Time unit used for the keepAlive valuethreadFactory- The factory used to create threads
-
OrderedThreadPoolExecutor
public OrderedThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, ThreadFactory threadFactory, IoEventQueueHandler eventQueueHandler) Creates a new instance of a OrderedThreadPoolExecutor.- Parameters:
corePoolSize- The initial pool sizePoolSizemaximumPoolSize- The maximum pool sizekeepAliveTime- Default duration for a threadunit- Time unit used for the keepAlive valuethreadFactory- The factory used to create threadseventQueueHandler- The queue used to store events
-
-
Method Details
-
getSessionTasksQueue
Get the session's tasks queue. -
getQueueHandler
- Returns:
- The associated queue handler.
-
setRejectedExecutionHandler
- Overrides:
setRejectedExecutionHandlerin classThreadPoolExecutor
-
addWorker
private void addWorker()Add a new thread to execute a task, if needed and possible. It depends on the current pool size. If it's full, we do nothing. -
addWorkerIfNecessary
private void addWorkerIfNecessary()Add a new Worker only if there are no idle worker. -
removeWorker
private void removeWorker() -
setMaximumPoolSize
public void setMaximumPoolSize(int maximumPoolSize) - Overrides:
setMaximumPoolSizein classThreadPoolExecutor
-
awaitTermination
- Specified by:
awaitTerminationin interfaceExecutorService- Overrides:
awaitTerminationin classThreadPoolExecutor- Throws:
InterruptedException
-
isShutdown
public boolean isShutdown()- Specified by:
isShutdownin interfaceExecutorService- Overrides:
isShutdownin classThreadPoolExecutor
-
isTerminated
public boolean isTerminated()- Specified by:
isTerminatedin interfaceExecutorService- Overrides:
isTerminatedin classThreadPoolExecutor
-
shutdown
public void shutdown()- Specified by:
shutdownin interfaceExecutorService- Overrides:
shutdownin classThreadPoolExecutor
-
shutdownNow
- Specified by:
shutdownNowin interfaceExecutorService- Overrides:
shutdownNowin classThreadPoolExecutor
-
print
-
execute
- Specified by:
executein interfaceExecutor- Overrides:
executein classThreadPoolExecutor
-
rejectTask
-
checkTaskType
-
getActiveCount
public int getActiveCount()- Overrides:
getActiveCountin classThreadPoolExecutor
-
getCompletedTaskCount
public long getCompletedTaskCount()- Overrides:
getCompletedTaskCountin classThreadPoolExecutor
-
getLargestPoolSize
public int getLargestPoolSize()- Overrides:
getLargestPoolSizein classThreadPoolExecutor
-
getPoolSize
public int getPoolSize()- Overrides:
getPoolSizein classThreadPoolExecutor
-
getTaskCount
public long getTaskCount()- Overrides:
getTaskCountin classThreadPoolExecutor
-
isTerminating
public boolean isTerminating()- Overrides:
isTerminatingin classThreadPoolExecutor
-
prestartAllCoreThreads
public int prestartAllCoreThreads()- Overrides:
prestartAllCoreThreadsin classThreadPoolExecutor
-
prestartCoreThread
public boolean prestartCoreThread()- Overrides:
prestartCoreThreadin classThreadPoolExecutor
-
getQueue
- Overrides:
getQueuein classThreadPoolExecutor
-
purge
public void purge()- Overrides:
purgein classThreadPoolExecutor
-
remove
- Overrides:
removein classThreadPoolExecutor
-
setCorePoolSize
public void setCorePoolSize(int corePoolSize) - Overrides:
setCorePoolSizein classThreadPoolExecutor
-