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官方文档