Linux服务器提交jar包的时候,出现:Error occurred during initialization of VM

本文探讨了在服务器上提交jar包或执行java-version命令时遇到的JVM内存分配错误,详细分析了错误原因,包括内存限制和overcommit_memory设置,并提供了解决方案,如调整overcommit_ratio。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

场景: 当在服务器上提交jar包,或者是执行java -version 的命令的时候,会出现如下提示

Error occurred during initialization of VM
Could not reserve enough space for object heap
Error: Could not create the Java Virtual Machine.
Error: A fatal exception has occurred. Program will exit.

有可能的原因是:当执行java -version 命令的时候,会将默认的jvm参数-Xmx500M -Xms500M设置为jvm启动参数,如果当前commited_as + 500M > commitLimit 且 overcommit_memory=2 ,那么就会出现上面的问题。

commited_as 和 commitLimit的值查看: grep -i commit /proc/meminfo

overcommit_memory的值查看: cat /proc/sys/vm/overcommit_memory

overcommit_ratio直接影响着commitLimit 的值成正相关(overcommit_ratio/100),查看: cat /proc/sys/vm/overcommit_ratio 

jvm的默认参数查看: 

java -XX:+PrintFlagsFinal -version | grep -i newsize     也可以用 PrintFlagsInitial 的参数

java -XX:+PrintCommandLineFlags -version                 这个会返回当前的初始化heapsize-->-XX:InitialHeapSize=1583109568 

===========================分隔线======================================

处理:只需要以root的身份执行  echo 60 > /proc/sys/vm/overcommit_ratio ,这里的参数根据实际生产的需要进行调整!

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值