在容器优化的操作系统上,Runtime.getRuntime().availableProcessors()始终返回1
我在GCP上的Kubernetes引擎上部署ElasticSearch,遇到性能问题。ElasticSearch根据内核数量确定各种线程池的大小。即使我创建了32核虚拟机,线程池大小也只有1。
我确实编写了一个测试程序来打印Runtime.getRuntime().availableProcessors()
,它只是打印为1。
我猜与容器优化操作系统有关,容器优化操作系统是使用Kubernetes引擎的虚拟机上唯一允许的操作系统。当我在GCP上创建Debian VM时,Runtime.getRuntime().availableProcessors()
返回8。不确定ElasticSearch在GCP Kubernetes引擎上是如何使用的。欢迎您提出任何想法或建议。
当我在没有Kubernetes的GCP上创建Debian VM时,Runtime.getRuntime().availableProcessors()
返回8。
解决方案
您可以尝试
-XX:ActiveProcessorCount=[host_cpu_count]
然后
Runtime.getRuntime().availableProcessors()
将返回
HOST_CPU_COUNT
相关文章