arthas的使用入门

常见问题

常见的现象,如下:

  • CPU占用率高,接口的响应时延大。
  • CPU占用率低,接口的响应时延大或者无响应。
  • 功能测试的场景下,CPU占用率超出预期。
  • 压力测试的场景下,CPU占用率低,压力增加后,吞吐量提升不明显,CPU占用率提升不明显。
  • 压缩测试的场景下,接口的时延不稳定,随着压力上升而上升。

可能的原因,如下:

  • 代码中出现了死锁
  • 代码中出现了死循环
  • 业务路径上存在耗时操作
  • 计算资源分配不均衡,比如线程池的数量分配不合理,CPU核的分配不合理
  • 内存资源的分配不合理
  • 资源的使用方面存在瓶颈

参考资料

JProfiler

在arthas诞生前,一般使用JProfiler工具定位问题,工具本身很强大,但是开发用机的硬件规格比较差,使用JProfiler挂载到被测试程序后运行时比较慢,虽然可以找到运行耗时的代码片段,最终定位到问题,但比较麻烦。

如下是相关的资料:

MAT

MAT即Memory Analyzer,基于eclipse框架开发,分析JVM堆的利器,一般常用于内存类问题的分析。

其它工具

JDK自带的工具,比如:

  • jstack -l
  • jmap
  • jstat
  • jhat
  • jps
  • jinfo
  • jvisualvm

Linux操作系统的工具,比如:

  • ps -ef
  • top -H -p <pid>

热门相关:隐婚101天:唐少宠妻成瘾   情妇3   千夫斩   汉阙   九阳剑圣