Runtime.getRuntime()。availableProcessors()在容器优化的OS上始终返回1

时间:2019-07-12 08:39:41

标签: java elasticsearch kubernetes google-kubernetes-engine

我正在GCP的kubernetes引擎上部署elasticsearch,并遇到性能问题。 Elasticsearch根据核心数量确定各种线程池的大小。即使创建了32核心VM,线程池大小也仅为1。

我确实写了一个测试程序来打印Runtime.getRuntime().availableProcessors(),它只是打印为1。

我想这与“容器优化的操作系统”有关,这是使用Kubernetes Engine在VM上允许的唯一操作系统。当我在GCP上创建Debian VM时,Runtime.getRuntime().availableProcessors()返回8。不确定在GCP的kubernetes引擎上如何使用elasticsearch。欢迎任何想法或建议。

当我在没有kubernetes的GCP上创建Debian VM时,Runtime.getRuntime().availableProcessors()返回8。

1 个答案:

答案 0 :(得分:3)

你可以试试

<块引用>

-XX:ActiveProcessorCount=[host_cpu_count]

然后

<块引用>

Runtime.getRuntime().availableProcessors()

会回来

<块引用>

host_cpu_count