Class ThreadPoolConfig
- java.lang.Object
-
- org.glassfish.tyrus.client.ThreadPoolConfig
-
public final class ThreadPoolConfig extends java.lang.ObjectClient thread pool configuration, which might be used to customize client thread pool.One can get a default
ThreadPoolConfigusingdefaultConfig()and customize it according to the application specific requirements.A
ThreadPoolConfigobject might be customized in a "Builder"-like fashion:ThreadPoolConfig.defaultConfig() .setPoolName("App1Pool") .setCorePoolSize(5) .setMaxPoolSize(10);- Author:
- Oleksiy Stashok, gustav trede
-
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description ThreadPoolConfigcopy()Return a copy of this thread pool config.static ThreadPoolConfigdefaultConfig()Create new client thread pool configuration instance.booleanequals(java.lang.Object o)intgetCorePoolSize()Get the core thread pool size - the size of the thread pool will never bee smaller than this.java.lang.ClassLoadergetInitialClassLoader()Get the class loader (if any) to be initially exposed by threads from this pool.longgetKeepAliveTime(java.util.concurrent.TimeUnit timeUnit)Get the max period of time a thread will wait for a new task to process.intgetMaxPoolSize()Get max thread pool size.java.lang.StringgetPoolName()Return thread pool name.intgetPriority()Get priority of the threads in thread pool.java.util.Queue<java.lang.Runnable>getQueue()Return a queue that will be used to temporarily store tasks when all threads in the thread pool are busy.intgetQueueLimit()Get the limit of the queue, where tasks are temporarily stored when all threads are busy.java.util.concurrent.ThreadFactorygetThreadFactory()ReturnThreadFactorythat will be used to create thread pool threads.inthashCode()booleanisDaemon()Returntrueif thread pool threads are daemons.ThreadPoolConfigsetCorePoolSize(int corePoolSize)Set the core thread pool size - the size of the thread pool will never bee smaller than this.ThreadPoolConfigsetDaemon(boolean isDaemon)Settrueif thread pool threads are daemons.ThreadPoolConfigsetInitialClassLoader(java.lang.ClassLoader initialClassLoader)Specifies the context class loader that will be used by threads in this pool.ThreadPoolConfigsetKeepAliveTime(long time, java.util.concurrent.TimeUnit unit)The max period of time a thread will wait for a new task to process.ThreadPoolConfigsetMaxPoolSize(int maxPoolSize)Set max thread pool size.ThreadPoolConfigsetPoolName(java.lang.String poolName)Set thread pool name.ThreadPoolConfigsetPriority(int priority)Set priority of the threads in thread pool.ThreadPoolConfigsetQueue(java.util.Queue<java.lang.Runnable> queue)Set a queue implementation that will be used to temporarily store tasks when all threads in the thread pool are busy.ThreadPoolConfigsetQueueLimit(int queueLimit)Set the limit of the queue, where tasks are temporarily stored when all threads are busy.ThreadPoolConfigsetThreadFactory(java.util.concurrent.ThreadFactory threadFactory)SetThreadFactorythat will be used to create thread pool threads.java.lang.StringtoString()
-
-
-
Method Detail
-
defaultConfig
public static ThreadPoolConfig defaultConfig()
Create new client thread pool configuration instance. The returnedThreadPoolConfiginstance will be pre-configured with a default values.- Returns:
- client thread pool configuration instance.
-
copy
public ThreadPoolConfig copy()
Return a copy of this thread pool config.- Returns:
- a copy of this thread pool config.
-
getQueue
public java.util.Queue<java.lang.Runnable> getQueue()
Return a queue that will be used to temporarily store tasks when all threads in the thread pool are busy.- Returns:
- queue that will be used to temporarily store tasks when all threads in the thread pool are busy.
-
setQueue
public ThreadPoolConfig setQueue(java.util.Queue<java.lang.Runnable> queue)
Set a queue implementation that will be used to temporarily store tasks when all threads in the thread pool are busy.- Parameters:
queue- queue implementation that will be used to temporarily store tasks when all threads in the thread pool are busy.- Returns:
- the
ThreadPoolConfigwith the newQueueimplementation.
-
getThreadFactory
public java.util.concurrent.ThreadFactory getThreadFactory()
ReturnThreadFactorythat will be used to create thread pool threads.If
ThreadFactoryis set, thenpriority,isDaemon,poolNamesettings will not be considered when creating new threads.- Returns:
ThreadFactorythat will be used to create thread pool threads.
-
setThreadFactory
public ThreadPoolConfig setThreadFactory(java.util.concurrent.ThreadFactory threadFactory)
SetThreadFactorythat will be used to create thread pool threads.- Parameters:
threadFactory- customThreadFactoryIfThreadFactoryis set, thenpriority,isDaemon,poolNamesettings will not be considered when creating new threads.- Returns:
- the
ThreadPoolConfigwith the newThreadFactory
-
getPoolName
public java.lang.String getPoolName()
Return thread pool name. The default is "Tyrus-client".- Returns:
- the thread pool name.
-
setPoolName
public ThreadPoolConfig setPoolName(java.lang.String poolName)
Set thread pool name. The default is "Tyrus-client".- Parameters:
poolName- the thread pool name.- Returns:
- the
ThreadPoolConfigwith the new thread pool name.
-
getPriority
public int getPriority()
Get priority of the threads in thread pool. The default isThread.NORM_PRIORITY.- Returns:
- priority of the threads in thread pool.
-
setPriority
public ThreadPoolConfig setPriority(int priority)
Set priority of the threads in thread pool. The default isThread.NORM_PRIORITY.- Parameters:
priority- of the threads in thread pool.- Returns:
- the
ThreadPoolConfigwith the new thread priority.
-
isDaemon
public boolean isDaemon()
Returntrueif thread pool threads are daemons. The default istrue.- Returns:
trueif thread pool threads are daemons.
-
setDaemon
public ThreadPoolConfig setDaemon(boolean isDaemon)
Settrueif thread pool threads are daemons. The default istrue.- Parameters:
isDaemon-trueif thread pool threads are daemons.- Returns:
- the
ThreadPoolConfigwith the daemon property set.
-
getMaxPoolSize
public int getMaxPoolSize()
Get max thread pool size. The default isMath.max(Runtime.getRuntime().availableProcessors(), 20)- Returns:
- max thread pool size.
-
setMaxPoolSize
public ThreadPoolConfig setMaxPoolSize(int maxPoolSize)
Set max thread pool size. The default is The default isMath.max(Runtime.getRuntime().availableProcessors(), 20).Cannot be smaller than 3.
- Parameters:
maxPoolSize- the max thread pool size.- Returns:
- the
ThreadPoolConfigwith the new max pool size set.
-
getCorePoolSize
public int getCorePoolSize()
Get the core thread pool size - the size of the thread pool will never bee smaller than this.The default is 1.
- Returns:
- the core thread pool size - the size of the thread pool will never bee smaller than this.
-
setCorePoolSize
public ThreadPoolConfig setCorePoolSize(int corePoolSize)
Set the core thread pool size - the size of the thread pool will never bee smaller than this.The default is 1.
- Parameters:
corePoolSize- the core thread pool size - the size of the thread pool will never bee smaller than this.- Returns:
- the
ThreadPoolConfigwith the new core pool size set.
-
getQueueLimit
public int getQueueLimit()
Get the limit of the queue, where tasks are temporarily stored when all threads are busy.Value less than 0 means unlimited queue. The default is -1.
- Returns:
- the thread-pool queue limit. The queue limit
-
setQueueLimit
public ThreadPoolConfig setQueueLimit(int queueLimit)
Set the limit of the queue, where tasks are temporarily stored when all threads are busy.Value less than 0 means unlimited queue. The default is -1.
- Parameters:
queueLimit- the thread pool queue limit. ThequeueLimitvalue less than 0 means unlimited queue.- Returns:
- the
ThreadPoolConfigwith the new queue limit.
-
setKeepAliveTime
public ThreadPoolConfig setKeepAliveTime(long time, java.util.concurrent.TimeUnit unit)
The max period of time a thread will wait for a new task to process.If the timeout expires and the thread is not a core one (see
setCorePoolSize(int),setMaxPoolSize(int)) - then the thread will be terminated and removed from the thread pool.The default is 10s.
- Parameters:
time- max keep alive timeout. The value less than 0 means no timeout.unit- time unit.- Returns:
- the
ThreadPoolConfigwith the new keep alive time.
-
getKeepAliveTime
public long getKeepAliveTime(java.util.concurrent.TimeUnit timeUnit)
Get the max period of time a thread will wait for a new task to process.If the timeout expires and the thread is not a core one (see
setCorePoolSize(int),setMaxPoolSize(int)) - then the thread will be terminated and removed from the thread pool.The default is 10s.
- Parameters:
timeUnit- time unit to which the result will be converted.- Returns:
- the keep-alive timeout, the value less than 0 means no timeout.
-
getInitialClassLoader
public java.lang.ClassLoader getInitialClassLoader()
Get the class loader (if any) to be initially exposed by threads from this pool.If not specified, the class loader of the parent thread that initialized the pool will be used.Authen
- Returns:
- the class loader (if any) to be initially exposed by threads from this pool.
-
setInitialClassLoader
public ThreadPoolConfig setInitialClassLoader(java.lang.ClassLoader initialClassLoader)
Specifies the context class loader that will be used by threads in this pool.If not specified, the class loader of the parent thread that initialized the pool will be used.
- Parameters:
initialClassLoader- the class loader to be exposed by threads of this pool.- Returns:
- the
ThreadPoolConfigwith the class loader set. - See Also:
Thread.getContextClassLoader()
-
toString
public java.lang.String toString()
- Overrides:
toStringin classjava.lang.Object
-
equals
public boolean equals(java.lang.Object o)
- Overrides:
equalsin classjava.lang.Object
-
hashCode
public int hashCode()
- Overrides:
hashCodein classjava.lang.Object
-
-