【JVM】调优常用参数总结
GC通用参数
-
-Xmn:年轻代
-
-Xss:栈空间
-
-Xms:初始堆大小
-
-Xmx:最大堆大小
-
-XX:NewSize=n:设置年轻代大小
-
-XX:NewRatio=n:设置年轻代和年老代的比值。如:为3,表示年轻代与年老代比值为1:3,年轻代占整个年轻代年老代和的1/4
-
-XX:SurvivorRatio=n:年轻代中Eden区与两个Survivor区的比值。注意Survivor区有两个。如:3,表示Eden:Survivor=3:2,一个Survivor区占整个年轻代的1/5
-
-XX:+UseTLAB:使用TLAB,默认打开
-
-XX:+PrintTLAB:打印TLAB的使用情况
-
-XX:TLABSize:设置TLAB大小(一般不建议改动)
-
-XX:+DisableExplictGC:线上环境一定要打开,避免写System.gc(),开启的话手动gc就不管用 ,FGC
-
-XX:+PrintGC:开启打印GC日志
-
-XX:+PrintGCDetails: 打印GC详细信息
-
-XX:+PrintHeapAtGC: 打印在发生GC时候的堆信息
-
-XX:+PrintGCTimeStamps:打印GC的时间
-
-XX:+PrintGCApplicationConcurrentTime:(重要性低) 打印应用程序时间
-
-XX:+PrintGCApplicationStoppedTime:(重要性低) 打印暂停时长
-
-XX:+PrintReferenceGC:(重要性低) 记录回收了多少种不同引用类型的引用
-
-verbose:class:类加载详细过程
-
-XX:+PrintVMOptions:打印JVM详细参数
-
-XX:+PrintFlagsFinal -XX:+PrintFlagsInitial:必须会用,java -XX:+PrintFlagsFinal -version | grep G1
-
-Xloggc:opt/log/gc.log
-
-XX:MaxTenuringThreshold:设置升代年龄,最大值15
-
-XX:PreBlockSpin:锁自旋次数 ,热点代码检测参数
-
-XX:CompileThreshold:逃逸分析 标量替换 ... 这些不建议设置
Parallel常用参数
-
-XX:SurvivorRatio:新生代中Eden区域和Survivor区域(From幸存区或To幸存区)的比例,默认为8
-
-XX:PreTenureSizeThreshold:大对象到底多大
-
-XX:MaxTenuringThreshold:进入老年代的年龄阈值,默认15(对象被复制的次数)
-
-XX:+ParallelGCThreads:并行收集器的线程数,同样适用于CMS,一般设为和CPU核数相同
-
-XX:+UseAdaptiveSizePolicy:自动选择各区大小比例
CMS常用参数
-
-XX:+UseConcMarkSweepGC:开启CMS垃圾回收
-
-XX:ParallelCMSThreads:设置CMS线程数量,一般为CPU核数的一半,CMS线程是在老年代,要留一些CPU给用户线程
-
-XX:CMSInitiatingOccupancyFraction:使用多少比例的老年代后开始CMS收集,默认是68%(近似值),如果频繁发生SerialOld卡顿,应该调小,(频繁CMS回收)
-
-XX:+UseCMSCompactAtFullCollection:在FGC时进行压缩
-
-XX:CMSFullGCsBeforeCompaction:多少次FGC之后进行压缩
-
-XX:+CMSClassUnloadingEnabled
-
-XX:CMSInitiatingPermOccupancyFraction:达到什么比例时进行Perm回收
-
GCTimeRatio:设置GC时间占用程序运行时间的百分比
-
-XX:MaxGCPauseMillis:停顿时间,是一个建议时间,GC会尝试用各种手段达到这个时间,比如减小年轻代
G1常用参数
-
-XX:+UseG1GC:开启G1垃圾回收
-
-XX:MaxGCPauseMillis:建议值,G1会尝试调整Young区的块数来达到这个值
-
-XX:+G1HeapRegionSize:分区大小,建议逐渐增大该值,1 2 4 8 16 32。 随着size增加,垃圾的存活时间更长,GC间隔更长,但每次GC的时间也会更长 ZGC做了改进(动态区块大小)
-
G1NewSizePercent:新生代最小比例,默认为5%
-
G1MaxNewSizePercent:新生代最大比例,默认为60%
-
GCTimeRatio:GC时间建议比例,G1会根据这个值调整堆空间
-
ConcGCThreads:线程数量
-
InitiatingHeapOccupancyPercent:启动G1的堆空间占用比例
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理