Class ThreadPools
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final intstatic final intstatic final intstatic final StringDeprecated.
- 
Method SummaryModifier and TypeMethodDescriptionstatic ScheduledExecutorServiceA sharedScheduledExecutorServicethat REST catalogs can use for refreshing their authentication data.static ExecutorServiceReturn anExecutorServicethat uses the "delete worker" thread-pool.static ExecutorServiceReturn anExecutorServicethat uses the "worker" thread-pool.static ScheduledExecutorServicenewExitingScheduledPool(String namePrefix, int poolSize, Duration terminationTimeout) Create a newScheduledExecutorServicewith the given name and pool size.static ExecutorServicenewExitingWorkerPool(String namePrefix, int poolSize) Creates a fixed-size thread pool that uses daemon threads and registers a shutdown hook to ensure the pool terminates when the JVM exits.static ExecutorServicenewFixedThreadPool(String namePrefix, int poolSize) Creates a fixed-size thread pool that uses daemon threads.static ScheduledExecutorServicenewScheduledPool(String namePrefix, int poolSize) Create a newScheduledExecutorServicewith the given name and pool size.static ExecutorServicenewWorkerPool(String namePrefix) Deprecated.will be removed in 2.0.0.static ExecutorServicenewWorkerPool(String namePrefix, int poolSize) Deprecated.will be removed in 2.0.0.
- 
Field Details- 
WORKER_THREAD_POOL_SIZE_PROPDeprecated.UseWORKER_THREAD_POOL_SIZEinstead; will be removed in 2.0.0
- 
WORKER_THREAD_POOL_SIZEpublic static final int WORKER_THREAD_POOL_SIZE
- 
DELETE_WORKER_THREAD_POOL_SIZEpublic static final int DELETE_WORKER_THREAD_POOL_SIZE
- 
AUTH_REFRESH_THREAD_POOL_SIZEpublic static final int AUTH_REFRESH_THREAD_POOL_SIZE
 
- 
- 
Method Details- 
getWorkerPoolReturn anExecutorServicethat uses the "worker" thread-pool.The size of the worker pool limits the number of tasks concurrently reading manifests in the base table implementation across all concurrent planning operations. The size of this thread-pool is controlled by the Java system property iceberg.worker.num-threads.- Returns:
- an ExecutorServicethat uses the worker pool
 
- 
getDeleteWorkerPoolReturn anExecutorServicethat uses the "delete worker" thread-pool.The size of this worker pool limits the number of tasks concurrently reading delete files within a single JVM. If there are multiple threads loading deletes, all of them will share this worker pool by default. The size of this thread-pool is controlled by the Java system property iceberg.worker.delete-num-threads.- Returns:
- an ExecutorServicethat uses the delete worker pool
 
- 
authRefreshPoolA sharedScheduledExecutorServicethat REST catalogs can use for refreshing their authentication data.
- 
newWorkerPoolDeprecated.will be removed in 2.0.0. UsenewExitingWorkerPool(String, int)for long-lived thread pools that require a shutdown hook, ornewFixedThreadPool(String, int)for short-lived thread pools where you manage the lifecycle.Creates a fixed-size thread pool that uses daemon threads. The pool is wrapped withMoreExecutors.getExitingExecutorService(ThreadPoolExecutor), which registers a shutdown hook to ensure the pool terminates when the JVM exits. Important: Even if the pool is explicitly shut down usingExecutorService.shutdown(), the shutdown hook is not removed. This can lead to accumulation of shutdown hooks if this method is used repeatedly for short-lived thread pools.For clarity and to avoid potential issues with shutdown hook accumulation, prefer using either newExitingWorkerPool(String, int)ornewFixedThreadPool(String, int), depending on the intended lifecycle of the thread pool.
- 
newWorkerPoolDeprecated.will be removed in 2.0.0. UsenewExitingWorkerPool(String, int)for long-lived thread pools that require a shutdown hook, ornewFixedThreadPool(String, int)for short-lived thread pools where you manage the lifecycle.Creates a fixed-size thread pool that uses daemon threads. The pool is wrapped withMoreExecutors.getExitingExecutorService(ThreadPoolExecutor), which registers a shutdown hook to ensure the pool terminates when the JVM exits. Important: Even if the pool is explicitly shut down usingExecutorService.shutdown(), the shutdown hook is not removed. This can lead to accumulation of shutdown hooks if this method is used repeatedly for short-lived thread pools.For clarity and to avoid potential issues with shutdown hook accumulation, prefer using either newExitingWorkerPool(String, int)ornewFixedThreadPool(String, int), depending on the intended lifecycle of the thread pool.
- 
newExitingWorkerPoolCreates a fixed-size thread pool that uses daemon threads and registers a shutdown hook to ensure the pool terminates when the JVM exits. This is suitable for long-lived thread pools that should be automatically cleaned up on JVM shutdown.
- 
newFixedThreadPoolCreates a fixed-size thread pool that uses daemon threads.
- 
newScheduledPoolCreate a newScheduledExecutorServicewith the given name and pool size.Threads used by this service will be daemon threads. - Parameters:
- namePrefix- a base name for threads in the executor service's thread pool
- poolSize- max number of threads to use
- Returns:
- an executor service
 
- 
newExitingScheduledPoolpublic static ScheduledExecutorService newExitingScheduledPool(String namePrefix, int poolSize, Duration terminationTimeout) Create a newScheduledExecutorServicewith the given name and pool size.Threads used by this service will be daemon threads. The service registers a shutdown hook to ensure that it terminates when the JVM exits. This is suitable for long-lived thread pools that should be automatically cleaned up on JVM shutdown. 
 
- 
WORKER_THREAD_POOL_SIZEinstead; will be removed in 2.0.0