JVM常用参数

java 复制代码
-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/home/my.hprof

如果出现OOM情况,在/home生成my.hprof文件

  1. 注意要保证文件不存在(文件名不重复),否则会生成失败
  2. 性能损耗可以忽略不计,在导出dump时会消耗一定性能,影响时间较短。而且都出现OOM了,这个文件还是很重要的
  3. dump文件的大小一般大于Xmx,如果Xmx很大不建议开启(比如在项目中Flink使用了60个G这种,用dump了也加载不出来)
java 复制代码
-Xms4096M

初始堆内存大小 Java启动时就会申请这么大的堆内存,如果内存不够则无法启动

java 复制代码
-Xmx4096M

最大堆内存大小 Java堆内存可以扩大到多少

Xms和Xmx要不要相同

  • 相同的情况下,JVM内存保持稳定,不会动态调整堆内存大小,没有堆内存调整的性能开销,稳定性较好
  • 不同的情况下,JVM动态调整堆内存大小会带来性能开销,在内存资源较紧张的情况下,可以先使用小的初始内存

目前个人感觉,服务需要稳定运行,内存资源不应该是问题,就算多花点钱扩大内存,在业务运行稳定目前是不值一提的,稳定的JVM比不可测的JVM更为重要

java 复制代码
-XX:+UseG1GC

使用G1垃圾回收器
CMS和G1怎么选择

据查询,在jdk8中,内存8G是一个分界线,低于8G时CMS性能较好,高于8G时G1性能较好,不绝对。

相关推荐
Unstoppable224 小时前
八股训练营第 37 天 | Java 内存区域有哪些部分?介绍一下什么是强引用、软引用、弱引用、虚引用?有哪些垃圾回收算法?有哪些垃圾回收器?
java·jvm·八股
没有bug.的程序员4 小时前
GC日志解析:从日志看全流程
java·网络·jvm·spring·日志·gc
稚辉君.MCA_P8_Java5 小时前
Gemini永久会员 深度解析jvm内存结构
jvm·后端·架构
廋到被风吹走8 小时前
【JDK版本】JDK1.8相比JDK1.7 JVM(Metaspace 与 G1 GC)
java·开发语言·jvm
stillaliveQEJ9 小时前
【JVM】基础概念之内存结构介绍
jvm
Zzzzzxl_9 小时前
互联网大厂Java/Agent面试:Spring Boot、JVM、微服务、RAG与向量检索实战问答
java·jvm·spring boot·kafka·rag·microservices·vectordb
铅笔侠_小龙虾18 小时前
Arthas 命令
java·jvm
上78将1 天前
JVM回收垃圾机制
java·开发语言·jvm
无敌最俊朗@1 天前
C++ 内存管理与编译原理 (面试复习2)
java·开发语言·jvm
酷ku的森1 天前
JVM垃圾回收机制
jvm