JVM知识总结(二)

JVM调优,什么是调优?
所谓调优,首先确定,追求啥?吞吐量优先,还是响应时间优先?还是在满足一定的响应时间的情况下,要求达到多大的吞吐量。如果要求吞吐量优先使用PS+PO;响应时间优先选择G1。根据需求进行JVM规划和预调优;优化运行JVM运行环境(慢,卡顿);解决JVM运行过程中出现的各种问题(OOM)。调优的两个条件:1、业务场景;2、监控,无监控不调优。熟悉业务场景(没有最好的垃圾回收器,只有最合适的垃圾回收器), 响应时间、停顿时间 [CMS G1 ZGC] (需要给用户作响应);吞吐量 = 用户时间 /( 用户时间 + GC时间) [PS]。选择回收器组合;计算内存的需求;选择CPU(越高越好);设定年代大小、升级年龄;设定日志参数-Xloggc:/opt/xxx/logs/xxx-xxx-gc-%t.log -XX:+UseGCLogFileRotation -XX:NumberOfGCLogFiles=5 -XX:GCLogFileSize=20M -XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+PrintGCCause; 或者每天产生一个日志文件;观察日志情况。
JVM常用的命令行参数参考官网:https://docs.oracle.com/javase/8/docs/technotes/tools/unix/java.html
HotSpot参数分类:- 标准参数,所有的HotSpot都支持;-X非标准参数:特定版本HotSpot支持特定命令;-XX不稳定:下个版本可能取消。
什么叫内存泄漏?什么叫内存溢出?
意思就是你用资源的时候为他开辟了一段空间,当你用完时忘记释放资源了,这时内存还被占用着,一次没关系,但是内存泄漏次数多了就会导致内存溢出
系统已经不能再分配出你所需要的空间,比如你需要50M的空间,系统只剩30M了,这就叫内存溢出
java -XX:+PrintCommandLineFlags -version使用这个命令查看默认参数

jdk自带的一些工具:
1、jdk提供的工具以及使用场景:1、jps:是JVM Process Status Tool的简称,可以列出正在运行的虚拟机进程,并显示虚拟机主类名称以及这些进程的本地虚拟机唯一ID。jps命令的相关参数-p只显示pid;-v输出虚拟机进程启动时的JVM参数;-m输出虚拟机启动时传递给主类main()函数的参数;-l输出主类全名,如果进程执行的时jar,则输出jar路径。2、jstat虚拟机统计信息监控工具全称JVM Statistical Monitoring Tool用于监视虚拟机各种运行状态信息的命令行工具,它可以显示虚拟机进程中类加载、内存、垃圾回收、即使编译等运行时数据。详细参数请看下图。3、jinfo:Java配置信息工具Configuration Info For Java的作用是实时查看和调整虚拟机各项参数;4、jmap:Java内存映射工具Memory Map For Java用户生成堆转储快照,

也可以通过-XX:+HeapDumpOnOutOfMemoryError参数来生成堆转储文件或者通过-XX:+HeapDumpOnCtrlBreak来生成在Linux环境下可以通过kill -3来拿到堆转储快照文件;具体参数请看下图。5、jhat:虚拟机堆转储快照分析工具JVM Heap Analysis Tool命令与jmap搭配使用,来分析生成的堆转储快照文件(一般不用)。6、jstack:Java堆栈跟踪工具Stack Trace for Java用户生

虚拟机当前时刻的线程快照,用户定位线程出现长时间停顿的原因;参数见下图。可以使用阿里的arthas来分析。jConsole:Java监视与管理控制台,

GC常用参数

  • -Xmn -Xms -Xmx -Xss
    年轻代 最小堆 最大堆 栈空间
  • -XX:+UseTLAB
    使用TLAB,默认打开
  • -XX:+PrintTLAB
    打印TLAB的使用情况
  • -XX:TLABSize
    设置TLAB大小
  • -XX:+DisableExplictGC
    System.gc()不管用 ,FGC
  • -XX:+PrintGC
  • -XX:+PrintGCDetails
  • -XX:+PrintHeapAtGC
  • -XX:+PrintGCTimeStamps
  • -XX:+PrintGCApplicationConcurrentTime (低)
    打印应用程序时间
  • -XX:+PrintGCApplicationStoppedTime (低)
    打印暂停时长
  • -XX:+PrintReferenceGC (重要性低)
    记录回收了多少种不同引用类型的引用
  • -verbose:class
    类加载详细过程
  • -XX:+PrintVMOptions
  • -XX:+PrintFlagsFinal -XX:+PrintFlagsInitial
    必须会用
  • -Xloggc:opt/log/gc.log
  • -XX:MaxTenuringThreshold
    升代年龄,最大值15
  • 锁自旋次数 -XX:PreBlockSpin 热点代码检测参数-XX:CompileThreshold 逃逸分析 标量替换 …
    这些不建议设置

Parallel常用参数

  • -XX:SurvivorRatio
  • -XX:PreTenureSizeThreshold
    大对象到底多大
  • -XX:MaxTenuringThreshold
  • -XX:+ParallelGCThreads
    并行收集器的线程数,同样适用于CMS,一般设为和CPU核数相同
  • -XX:+UseAdaptiveSizePolicy
    自动选择各区大小比例

CMS常用参数

  • -XX:+UseConcMarkSweepGC
  • -XX:ParallelCMSThreads
    CMS线程数量
  • -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
  • -XX:MaxGCPauseMillis
    建议值,G1会尝试调整Young区的块数来达到这个值
  • -XX:GCPauseIntervalMillis
    ?GC的间隔时间
  • -XX:+G1HeapRegionSize
    分区大小,建议逐渐增大该值,1 2 4 8 16 32。
    随着size增加,垃圾的存活时间更长,GC间隔更长,但每次GC的时间也会更长
    ZGC做了改进(动态区块大小)
  • G1NewSizePercent
    新生代最小比例,默认为5%
  • G1MaxNewSizePercent
    新生代最大比例,默认为60%
  • GCTimeRatio
    GC时间建议比例,G1会根据这个值调整堆空间
  • ConcGCThreads
    线程数量
  • InitiatingHeapOccupancyPercent
    启动G1的堆空间占用比例
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值