Java性能优化实战

文章介绍了如何使用Arthas工具定位并优化接口性能问题,包括通过trace命令监控方法执行时间,解决SQL执行效率低下的问题,如添加索引和避免无谓的排序,以及调整Java堆空间以减少频繁GC导致的性能影响。
摘要由CSDN通过智能技术生成

实际工作中如何 优化接口性能:

  1. 使用arthas定位到占用时间最长的方法。

1.1 下载arthas curl -O https://arthas.aliyun.com/arthas-boot.jar

1.2 启动arthas监控Java程序,java -jar arthas-boot.jar

1.3 使用trace命令监控方法执行时间,trace 全限定类名 方法名

  1. 进行具体分析

  1. 工作中遇到的性能差的解决方案

3.1 sql执行时间长

数据库中数据量大,查询条件没有加索引,可以考虑加上索引。

select count(*)查询时间长,查询总记录条数的时候不用加order by,有多种情况可能导致排序使用不上索引,比如子查询或者连表,连表的时候mysql默认使用小表驱动,大表上的索引使用不到。

3.2 堆空间太小,频繁GC,导致接口性能很差

单线程连续调用同一个接口,发现接口响应时间相差很大,arthas里面输入dashboard命令,发现频繁yongGC,调大堆空间初始大小,情况有好转。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值