The following topic describes the MBeans tab and the recommended number of threads in the pool.
The MBeans tab provides access to the JMX Managed Beans and their available attributes and operations. Of particular interest are the queuedthreadpool instances that are available within the org.eclipse.jetty.util.thread bean. For example, instance 0 represents the thread pool that handles runtime requests. When you click the Attributes item for instance 0, the current state of the thread pool is displayed.
The number of threads in the pool (the threads
attribute) can be
compared to the number of threads that are not currently in use (the
idleThreads
attribute). Ideally, a sufficient number of threads is
available to handle load spikes that occur during peak usage times, while also limiting
the number of idle threads that are running. If the thread pool is too small, requests
might be blocked. If the thread pool is too large, memory might be used unnecessarily,
and CPU contention might increase, limiting the processing effectiveness.
We recommend allowing for 10 to 25% more threads than are typically active while the system executes a normal or expected load. Because most of your users will not be active at the same time, set the minimum threads to 10% above the average number of active threads that are observed during monitoring.
We also recommend setting the maximum number of threads to 25% above the average number of active threads that are observed while monitoring under expected load conditions. Make certain to weigh this recommendation against the observed CPU utilization metrics and the suggestions in the Performance Tuning Guide.