You can specify the minimum and maximum number of threads that are reserved for requests from applications. The thread pool is dynamically adjusted between these two values.
The following topics are addressed here:
 To Create a Thread Pool
To Create a Thread PoolUse the create-threadpool subcommand in remote mode to create a thread pool.
The minimum thread pool size that is specified signals the server to allocate at least that many threads in reserve for application requests. That number is increased up to the maximum thread pool size that is specified. Increasing the number of threads available to a process allows the process to respond to more application requests simultaneously.
If one resource adapter or application occupies all the GlassFish Server threads, thread starvation might occur. You can avoid this by dividing the GlassFish Server threads into different thread pools.
Ensure that the server is running.
Remote subcommands require a running server.
Create a new thread pool by using the create-threadpool(1) subcommand.
Information about options for the subcommand is included in this help page.
To apply your changes, restart GlassFish Server.
See To Restart a Domain.
Restart is not necessary for thread pools used by the web container.
This example creates threadpool-l.
| asadmin> create-threadpool --maxthreadpoolsize 100 
      --minthreadpoolsize 20 --idletimeout 2 --workqueues 100 threadpool-1
Command create-threadpool executed successfully | 
You can also view the full syntax and options of the subcommand by typing asadmin help create-threadpool at the command line.
 To List Thread Pools
To List Thread PoolsUse the list-threadpools subcommand in remote mode to list the existing thread pools.
Ensure that the server is running.
Remote subcommands require a running server.
List the existing thread pools by using the list-threadpools(1) subcommand.
This example lists the existing thread pools.
| asadmin> list-threadpools threadpool-1 Command list-threadpools executed successfully | 
You can also view the full syntax and options of the subcommand by typing asadmin help list-threadpools at the command line.
 To Update a Thread Pool
To Update a Thread PoolUse the set subcommand to update the values for a specified thread pool.
List the existing thread pools by using the list-threadpools(1) subcommand.
Modify the values for a thread pool by using the set(1) subcommand.
The thread pool is identified by its dotted name.
To apply your changes, restart GlassFish Server.
See To Restart a Domain.
Restart is not necessary for thread pools used by the web container.
This example sets the max-thread-pool-size from its previous value to 8.
| asadmin> set server.thread-pools.thread-pool.http-thread-pool.max-thread-pool-size=8 Command set executed successfully | 
You can also view the full syntax and options of the subcommand by typing asadmin help set at the command line.
 To Delete a Thread Pool
To Delete a Thread PoolUse the delete-threadpool subcommand in remote mode to delete an existing thread pool. Deleting a thread pool will fail if that pool is referenced by a network listener.
Ensure that the server is running.
Remote subcommands require a running server.
List the existing thread pools by using the list-threadpools(1) subcommand.
Delete the specified thread pool by using the delete-threadpool(1) subcommand.
To apply your changes, restart GlassFish Server.
See To Restart a Domain.
Restart is not necessary for thread pools used by the web container.
This example deletes threadpool-1.
| asadmin> delete-threadpool threadpool-1 Command delete-threadpool executed successfully | 
You can also view the full syntax and options of the subcommand by typing asadmin help delete-threadpool at the command line.