常见问题
常见的现象,如下:
- 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操作系统的工具,比如:
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |