You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@hc.apache.org by "Elijah Zupancic (JIRA)" <ji...@apache.org> on 2018/02/05 22:08:00 UTC
[jira] [Created] (HTTPCORE-509) AVAIL_PROCS is autoconfigured based
on core count
Elijah Zupancic created HTTPCORE-509:
----------------------------------------
Summary: AVAIL_PROCS is autoconfigured based on core count
Key: HTTPCORE-509
URL: https://issues.apache.org/jira/browse/HTTPCORE-509
Project: HttpComponents HttpCore
Issue Type: Bug
Components: HttpCore NIO
Affects Versions: 4.4.9
Reporter: Elijah Zupancic
In [IOReactorConfig:39|
https://github.com/apache/httpcomponents-core/blob/92c4c6ff64a9a4a0b0677338c03ebd24bfe1b219/httpcore-nio/src/main/java/org/apache/http/impl/nio/reactor/IOReactorConfig.java#L39
], the default value for thread count is based on the detected cores on the system. This is usually acceptable. However, if the library is being run within a container where the reported number of CPUs does not match the actual amount of CPU available, you will see too many threads created in the pool leading to performance degradation.
Of course a direct user of this library will be able to set this value to a sensible number. However, you will typically see httpcore-nio 4-5 steps down the dependency graph and it is being used by other open source components which in turn are being used by other components.
I would suggest that we optionally read a system parameter for the value of AVAIL_PROCS. If that system parameter is not available, then we use the value of Runtime.getRuntime().availableProcessors();
--
This message was sent by Atlassian JIRA
(v7.6.3#76005)
---------------------------------------------------------------------
To unsubscribe, e-mail: dev-unsubscribe@hc.apache.org
For additional commands, e-mail: dev-help@hc.apache.org