Runtime.getRuntime().availableProcessors() is always returning 1 on Container-Optimized OS(在容器优化的操作系统上,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
这篇关于在容器优化的操作系统上,Runtime.getRuntime().availableProcessors()始终返回1的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:在容器优化的操作系统上,Runtime.getRuntime().availableProcessors()始终返回1


基础教程推荐
- 使用堆栈算法进行括号/括号匹配 2022-01-01
- 如何对 Java Hashmap 中的值求和 2022-01-01
- 修改 void 函数的输入参数,然后读取 2022-01-01
- Spring AOP错误无法懒惰地为此建议构建thisJoinPoin 2022-09-13
- 存储 20 位数字的数据类型 2022-01-01
- 无法复制:“比较方法违反了它的一般约定!" 2022-01-01
- RabbitMQ:消息保持“未确认"; 2022-01-01
- 问题http://apache.org/xml/features/xinclude测试日志4j 2 2022-01-01
- Struts2 URL 无法访问 2022-01-01
- REST Web 服务返回 415 - 不支持的媒体类型 2022-01-01