Package org.eclipse.jetty.util.thread
Class ExecutorThreadPool
java.lang.Object
org.eclipse.jetty.util.component.AbstractLifeCycle
org.eclipse.jetty.util.component.ContainerLifeCycle
org.eclipse.jetty.util.thread.ExecutorThreadPool
- All Implemented Interfaces:
Executor,Container,Destroyable,Dumpable,Dumpable.DumpableContainer,LifeCycle,ThreadPool,ThreadPool.SizedThreadPool,TryExecutor,VirtualThreads.Configurable
@ManagedObject("A thread pool")
public class ExecutorThreadPool
extends ContainerLifeCycle
implements ThreadPool.SizedThreadPool, TryExecutor, VirtualThreads.Configurable
A
ThreadPool.SizedThreadPool wrapper around ThreadPoolExecutor.-
Nested Class Summary
Nested classes/interfaces inherited from class org.eclipse.jetty.util.component.AbstractLifeCycle
AbstractLifeCycle.AbstractLifeCycleListener, AbstractLifeCycle.StopExceptionNested classes/interfaces inherited from interface org.eclipse.jetty.util.component.Container
Container.InheritedListener, Container.ListenerNested classes/interfaces inherited from interface org.eclipse.jetty.util.component.Dumpable
Dumpable.DumpableContainerNested classes/interfaces inherited from interface org.eclipse.jetty.util.component.LifeCycle
LifeCycle.ListenerNested classes/interfaces inherited from interface org.eclipse.jetty.util.thread.ThreadPool
ThreadPool.SizedThreadPoolNested classes/interfaces inherited from interface org.eclipse.jetty.util.thread.TryExecutor
TryExecutor.NoTryExecutor -
Field Summary
Fields inherited from class org.eclipse.jetty.util.component.AbstractLifeCycle
FAILED, STARTED, STARTING, STOPPED, STOPPINGFields inherited from interface org.eclipse.jetty.util.thread.TryExecutor
NO_TRY -
Constructor Summary
ConstructorsConstructorDescriptionExecutorThreadPool(int maxThreads) ExecutorThreadPool(int maxThreads, int minThreads) ExecutorThreadPool(int maxThreads, int minThreads, BlockingQueue<Runnable> queue) ExecutorThreadPool(ThreadPoolExecutor executor) ExecutorThreadPool(ThreadPoolExecutor executor, int reservedThreads) ExecutorThreadPool(ThreadPoolExecutor executor, int reservedThreads, ThreadGroup group) -
Method Summary
Modifier and TypeMethodDescriptionprotected voiddoStart()Starts the managed lifecycle beans in the order they were added.protected voiddoStop()Stops the managed lifecycle beans in the reverse order they were added.voiddump(Appendable out, String indent) Dump this object (and children) into an Appendable using the provided indent after any new lines.voidintintintintgetName()intintintbooleanisDaemon()booleanbooleanvoidjoin()Blocks until the thread pool isstopped.protected ThreadvoidsetDaemon(boolean daemon) voidsetDetailedDump(boolean detailedDump) voidsetIdleTimeout(int idleTimeout) Sets the maximum thread idle time in ms.voidsetMaxThreads(int threads) voidsetMinThreads(int threads) voidvoidsetReservedThreads(int reservedThreads) Sets the number of reserved threads.voidsetThreadsPriority(int priority) voidsetVirtualThreadsExecutor(Executor executor) toString()booleantryExecute(Runnable task) Attempt to execute a task.Methods inherited from class org.eclipse.jetty.util.component.ContainerLifeCycle
addBean, addBean, addEventListener, addManaged, contains, destroy, dump, dump, dumpObjects, dumpStdErr, getBean, getBeans, getBeans, getContainedBeans, getContainedBeans, isAuto, isManaged, isUnmanaged, manage, removeBean, removeBeans, removeEventListener, setBeans, start, stop, unmanage, updateBean, updateBean, updateBeans, updateBeansMethods inherited from class org.eclipse.jetty.util.component.AbstractLifeCycle
getEventListeners, getState, getState, isFailed, isRunning, isStarted, isStarting, isStopped, isStopping, setEventListeners, start, stopMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface org.eclipse.jetty.util.component.Container
getCachedBeans, getEventListenersMethods inherited from interface org.eclipse.jetty.util.component.Dumpable.DumpableContainer
isDumpableMethods inherited from interface org.eclipse.jetty.util.VirtualThreads.Configurable
isUseVirtualThreads, setUseVirtualThreads
-
Constructor Details
-
ExecutorThreadPool
public ExecutorThreadPool() -
ExecutorThreadPool
public ExecutorThreadPool(int maxThreads) -
ExecutorThreadPool
public ExecutorThreadPool(int maxThreads, int minThreads) -
ExecutorThreadPool
-
ExecutorThreadPool
-
ExecutorThreadPool
-
ExecutorThreadPool
-
-
Method Details
-
getName
- Returns:
- the name of the this thread pool
-
setName
- Parameters:
name- the name of this thread pool, used to name threads
-
getMinThreads
- Specified by:
getMinThreadsin interfaceThreadPool.SizedThreadPool- Returns:
- the minimum number of threads
-
setMinThreads
public void setMinThreads(int threads) - Specified by:
setMinThreadsin interfaceThreadPool.SizedThreadPool- Parameters:
threads- the minimum number of threads
-
getMaxThreads
- Specified by:
getMaxThreadsin interfaceThreadPool.SizedThreadPool- Returns:
- the maximum number of threads
-
setMaxThreads
public void setMaxThreads(int threads) - Specified by:
setMaxThreadsin interfaceThreadPool.SizedThreadPool- Parameters:
threads- the maximum number of threads
-
getIdleTimeout
- Returns:
- the maximum thread idle time in ms.
- See Also:
-
setIdleTimeout
public void setIdleTimeout(int idleTimeout) Sets the maximum thread idle time in ms.
Threads that are idle for longer than this period may be stopped.
- Parameters:
idleTimeout- the maximum thread idle time in ms.- See Also:
-
getReservedThreads
- Returns:
- number of reserved threads or -1 to indicate that the number is heuristically determined
- See Also:
-
setReservedThreads
public void setReservedThreads(int reservedThreads) Sets the number of reserved threads.- Parameters:
reservedThreads- number of reserved threads or -1 to determine the number heuristically- See Also:
-
setThreadsPriority
public void setThreadsPriority(int priority) -
getThreadsPriority
public int getThreadsPriority() -
isDaemon
- Returns:
- whether this thread pool uses daemon threads
- See Also:
-
setDaemon
public void setDaemon(boolean daemon) - Parameters:
daemon- whether this thread pool uses daemon threads- See Also:
-
isDetailedDump
-
setDetailedDump
public void setDetailedDump(boolean detailedDump) -
getThreads
- Specified by:
getThreadsin interfaceThreadPool- Returns:
- The total number of threads currently in the pool
-
getIdleThreads
- Specified by:
getIdleThreadsin interfaceThreadPool- Returns:
- The number of idle threads in the pool
-
execute
- Specified by:
executein interfaceExecutor- Specified by:
executein interfaceTryExecutor
-
tryExecute
Description copied from interface:TryExecutorAttempt to execute a task.- Specified by:
tryExecutein interfaceTryExecutor- Parameters:
task- The task to be executed- Returns:
- True IFF the task has been given directly to a thread to execute. The task cannot be queued pending the later availability of a Thread.
-
isLowOnThreads
@ManagedAttribute(value="thread pool is low on threads", readonly=true) public boolean isLowOnThreads()- Specified by:
isLowOnThreadsin interfaceThreadPool- Returns:
- True if the pool is low on threads
-
getVirtualThreadsExecutor
- Specified by:
getVirtualThreadsExecutorin interfaceVirtualThreads.Configurable- Returns:
- the
Executorto use to execute tasks in virtual threads
-
setVirtualThreadsExecutor
- Specified by:
setVirtualThreadsExecutorin interfaceVirtualThreads.Configurable- Parameters:
executor- theExecutorto use to execute tasks in virtual threads- See Also:
-
doStart
Description copied from class:ContainerLifeCycleStarts the managed lifecycle beans in the order they were added.- Overrides:
doStartin classContainerLifeCycle- Throws:
AbstractLifeCycle.StopException- If thrown, the lifecycle will immediately be stopped.Exception- If there was a problem starting. Will cause a transition to FAILED state
-
doStop
Description copied from class:ContainerLifeCycleStops the managed lifecycle beans in the reverse order they were added.- Overrides:
doStopin classContainerLifeCycle- Throws:
Exception- If there was a problem stopping. Will cause a transition to FAILED state
-
join
Description copied from interface:ThreadPoolBlocks until the thread pool isstopped.- Specified by:
joinin interfaceThreadPool- Throws:
InterruptedException- if thread was interrupted
-
getThreadPoolBudget
- Specified by:
getThreadPoolBudgetin interfaceThreadPool.SizedThreadPool- Returns:
- a ThreadPoolBudget for this sized thread pool, or null of no ThreadPoolBudget can be returned
-
newThread
-
dump
Description copied from interface:DumpableDump this object (and children) into an Appendable using the provided indent after any new lines. The indent should not be applied to the first object dumped.- Specified by:
dumpin interfaceDumpable- Overrides:
dumpin classContainerLifeCycle- Parameters:
out- The appendable to dump toindent- The indent to apply after any new lines.- Throws:
IOException- if unable to write to Appendable
-
toString
- Overrides:
toStringin classAbstractLifeCycle
-