JVM-GC-常用调优命令和GC参数

定位问题常用命令

  1. top:查看内存/CPU占用情况
  2. top -Hp pid: 查看进程内线程情况
  3. jsp:查看java进程情况
  4. jstack 线程pid:查看进程内线程信息,一般查看线程状态,判断是否死锁。重点观察:WAITING、BLOCKED的线程,另外查看waiting on xxx,如果多个线程都在waiting on 某把锁,看哪个线程持有这把锁;
  5. jstat -gc:查看GC情况
  6. jinfo 线程pid:查看线程信息
  7. jstat -gc 线程pid 间隔时间:查看
  8. jmap -histo 线程pid | head 20:查看那些对象多,用于定位OOM问题;
  9. jmap -dump:format=b,file=xxx pid:导出堆栈信息,消耗性能,生产环境慎用;

JVM调优常用工具

  1. jconsole:JDK自带,消耗性能,线上排查慎用;
  2. arthas:推荐使用,线上排查;

GC常用参数

  1. -Xmn/-Xms/-Xmx/-Xss:年轻代/最小堆/最大堆/栈空间大小
  2. -XX:+PrintVMOptions:打印JVM运行参数
  3. -XX:+PrintFlagsFinal:打印JVM最终参数,配合管道符搜索命令 如:-XX:+PrintFlagsFinal | CMS
  4. -XX:+PrintFlagsInitial:打印JVM默认参数
  5. -XX:MaxTenuringThreshold:升代年龄,两位存储,最大15
  6. -XX:+PrintGC
  7. -XX:+PrintGCDetails
  8. -XX:+PrintHeapAtGC
  9. -XX:+PrintGCTimeStamps
  10. -XX:+UseTLAB:使用TLAB,默认打开
  11. -XX:+PrintTLAB:打印TLAB情况
  12. -XX:TLABSize:TLAB大小
  13. -XX:DisableExplictGC:禁用System.gc()
  14. -XX:+PrintGCApplicationConcurrentTime:打印应用程序时间
  15. -XX:+PrintGCApplicationStoppedTime:打印暂停时间
  16. -XX:+PrintReferenceGC:记录回收了多少种不同引用对象
  17. -verbose:class:类加载详细过程

Parallel常用参数

  1. -XX:SurvivorRatio:
  2. -XX:PreTenureSizeThreshold:设置大对象大小,指定之间分配到Old区对象大小
  3. -XX:MaxTenuringThreshold:升代年龄,两位存储,最大15
  4. -XX:+ParallelGCThreads:并发收集器线程数,同样适用CMS,一般和CPU核数相同
  5. -XX:+UseAdaptiveSizePolicy:自动选择各区大小比例

CMS常用参数

  1. -XX:ParallelCMSThreads:设置CMS线程数
  2. -XX:CMSInitiatingOccupancyFraction:使用多少老年代空间比例后开始CMS回收,默认68%
  3. -XX:+UseCMSCompactAtFullCollection:在FGC时进行压缩
  4. -XX:CMSFullGCsBeforeCompaction:在多少次FGC后进行压缩
  5. -XX:+CMSClassUnloadingEnabled:回收没用的class,永久代回收
  6. -XX:CMSInitiatingPermOccupancyFraction:永久代达到这个比例后触发CMS
  7. -XX:GCTimeRatio:设置GC时间占用程序时间百分比
  8. -XX:MaxGCPauseMillis:停顿时间,是一个建议时间。

G1常用参数

  1. -XX:+UseG1GC:使用G1
  2. -XX:MaxGCPauseMillis:停顿时间,是一个建议时间。G1通过减少young区块数 达到这个值
  3. -XX:+G1HeapRegionSize:设置分区大小,只能设置1、2、4、8、16、32;值越大垃圾存活时间越长,间隔越长,回收时间越长
  4. -XX:G1NewSizePercent:新生代最小比例,默认为5%
  5. -XX:G1MaxNewSizePercent:新生代最大比例,默认60%
  6. -XX:GCTimeRatio:GC时间建议比例,G1会根据这个值调整堆空间
  7. -XX:ConcGCThreads:GC线程数量
  8. -XX:InitiatingHeapOccupancyPercent:启动G1的堆空间占比例

GC日志(PS+PO)

请添加图片描述

  • 14
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值