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虚拟机

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值