栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

JVM的默认内存是怎么分配的?

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

JVM的默认内存是怎么分配的?

JVM

当运行java程序出现OOM问题时,其实第一个想到的解决方法就是 增加机子内存,但是很简单的将机子内存由4G升级到了8G,这时就会成功运行java程序。

为什么简单的增大了内存就会做到这一点呢?我又没有修改jvm的参数。

每一个java程序会对应一个jvm实例,都有自己的程序执行空间,每一个都有一套jvm虚拟机机制

spark会使用堆外内存进行storage和execution,但是默认是关闭的

然后通过
java -XX:+PrintFlagsFinal -version | grep -iE 'HeapSize'命令,查看jvm的默认堆大小。
当我把虚拟机内存调整为4G时

调整为8G时

MaxHeapSize(最大堆大小)就是Xmx的默认值,InitialHeapSize(最小堆大小)时Xms的默认值,默认值和Java的版本有关,Linux中的版本是Java8,Xmx的默认值是当前系统ram的四分之一 .
因此增大服务器的物理内存,jvm的默认堆内存大小是自动调整的。

参考

JVM出现OOM的八种原因及解决办法
在Linux中查看Java堆大小,Xmx、Xms的默认值和当前运行时的设置值
java8官方文档

一台机器上有几个java虚拟机

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/872798.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号