Java HotSpot(TM) 64-Bit Server VM warning: INFO: os::commit_memory(0x00000000fa980000, 59244544, 0) failed; error=’Cannot allocate memory’ (errno=12)详解编程语言

启动项目报错

Java HotSpot(TM) 64-Bit Server VM warning: INFO: os::commit_memory(0x00000000fa980000, 59244544, 0) failed; error='Cannot allocate memory' (errno=12) 
# There is insufficient memory for the Java Runtime Environment to continue. 
# Native memory allocation (mmap) failed to map 59244544 bytes for committing reserved memory. 
# An error report file with more information is saved as: 
# /root/.jenkins/workspace/tbvp/src/hs_err_pid17078.log

报错原因:项目启动内存不足

解决办法

修改项目启动内存
java -Xms1048m -Xmx1048m -Xss512k -jar xxx.jar

参数解释

-server:一定要作为第一个参数,在多个CPU时性能佳 
-Xms:初始Heap大小,使用的最小内存,cpu性能高时此值应设的大一些 
-Xmx:java heap最大值,使用的最大内存 
上面两个值是分配JVM的最小和最大内存,取决于硬件物理内存的大小,建议均设为物理内存的一半。 
-XX:PermSize:设定内存的永久保存区域 
-XX:MaxPermSize:设定最大内存的永久保存区域 
-XX:MaxNewSize: 
-Xss 15120 这使得JBoss每增加一个线程(thread)就会立即消耗15M内存,而最佳值应该是128K,默认值好像是512k. 
+XX:AggressiveHeap 会使得 Xms没有意义。这个参数让jvm忽略Xmx参数,疯狂地吃完一个G物理内存,再吃尽一个G的swap。 
-Xss:每个线程的Stack大小 
-verbose:gc 现实垃圾收集信息 
-Xloggc:gc.log 指定垃圾收集日志文件 
-Xmn:young generation的heap大小,一般设置为Xmx的3、4分之一 
-XX:+UseParNewGC :缩短minor收集的时间 
-XX:+UseConcMarkSweepGC :缩短major收集的时间 
提示:此选项在Heap Size 比较大而且Major收集时间较长的情况下使用更合适。

原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/16483.html

(0)
上一篇 2021年7月19日
下一篇 2021年7月19日

相关推荐

发表回复

登录后才能评论