经典面试题 之 JVM调优

本文介绍了JVM调优的关键概念,如吞吐量和响应时间,并提供了调优步骤,包括选择合适的垃圾回收器、规划内存和CPU选择。针对CPU使用率过高和内存飙高问题,给出了定位和解决策略。同时,详细列举了各种JVM调优参数,包括CMS、G1等垃圾回收器的相关设置。
摘要由CSDN通过智能技术生成

在这里插入图片描述

JVM调优涉及到两个很重要的概念:吞吐量和响应时间。jvm调优主要是针对他们进行调整优化,达到一个理想的目标,根据业务确定目标是吞吐量优先还是响应时间优先。

  • 吞吐量:用户代码执行时间/(用户代码执行时间+GC执行时间)。
  • 响应时间:整个接口的响应时间(用户代码执行时间+GC执行时间),stw时间越短,响应时间越短。 

一、调优步骤
        调优的前提是熟悉业务场景,先判断出当前业务场景是吞吐量优先还是响应时间优先。调优需要建立在监控之上,由压力测试来判断是否达到业务要求和性能要求。

        调优的步骤大致可以分为:

        1.熟悉业务场景,了解当前业务系统的要求,是吞吐量优先还是响应时间优先;

        2.选择合适的垃圾回收器组合,如果是吞吐量优先,则选择ps+po组合;如果是响应时间优先,在1.8以后选择G1,在1.8之前选择ParNew+CMS组合;

        3.规划内存需求,只能进行大致的规划。

        4.CPU选择,在预算之内性能越高越好;

        5.根据实际情况设置升级年龄,最大年龄为15;

        6.设定日志参数:-Xloggc:/path/name-gc-%t.log -XX:+UseGCLogFileRotation -XX:NumberOfGCLogs=5 -XX:GCLogFileSize=20M -XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+PrintGCCauses

        -XX:+UseGCLogFileRotation:GC文件循环使用

        -XX:NumberOfGCLogs=5:使用5个GC文件

        -XX:GCLogFileSize=20M:每个GC文件的大小

        上面这三个参数放在一起代表的含义是:5个GC文件循环使用,每个GC文件20M,总共使用100M存储日志文件,当5个GC文件都使用完毕以后,覆盖第一个GC日志文件,生成新的GC文件。

二、CPU使用率飙高

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值