JVM调优常用参数总结
GC通用参数
-Xmn -Xms -Xmx -Xss
年轻代 最小堆 最大堆 栈空间
-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的堆空间占用比例
最新文章
- 字节流VS缓冲流
- iOS 目录的使用
- AngularJS Best Practices: ASP.NET MVC Directory Structure
- Java String类中的intern()方法
- 在MongoDB中实现聚合函数 (转)
- NOI 国家集训队论文集
- [原][Android]All WebView methods must be called on the same thread.
- [转]jQuery选择器总结
- MD5加密详解
- Android studio听云接入另外一种方式
- 两个栈实现队列+两个队列实现栈----java
- IP地址和子网掩码
- Android依赖注入:Google Guice on Android的使用及相关资源
- Visual Studio 2015创建ASP.NET5项目“DNX SDK version 'dnx-clr-win-x86.1.0.0-beta5' 无法安装的错误
- 微信中通过页面(H5)直接打开本地app的解决方案
- sublime中配置Java 环境
- VFS四大对象之四-struct file
- C++ gui程序附加dos输出窗口
- 测试同学必备抓包工具--charles之mock数据
- 大疆ganluinace
热门文章
- How to avoid multiple definition of function with gcc
- [bash] 获取linux主机名,检视内中是否有特定字符串
- 8.ffmpeg-基础常用知识
- vue 实现原理及简单示例实现
- docker下jira数据备份和还原注意路径
- 第0课 - 搭建开发环境之安装QT
- Scala的lazy应用
- ActiveMQ客户端Apache.NMS从.net 4.0移植到.net standard 2.0
- matlab外部程序接口-excel
- CAS导致的ABA问题以及解决方案