在容器优化的操作系统上,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

相关文章