我正在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。
答案 0 :(得分:3)
你可以试试
<块引用>-XX:ActiveProcessorCount=[host_cpu_count]
然后
<块引用>Runtime.getRuntime().availableProcessors()
会回来
<块引用>host_cpu_count