从Jmeter入门到JVM调优实战

1. 相关文档

2. Jmeter UI功能介绍

1)创建线程组 2)创建HTTP请求 加个请求头 3)添加监听器-查看结果树 4)安装Jemeter插件:3 Basic Graphs、5 Additional Graphs 和 PerfMon(服务器性能监控插件) 5)运行服务端的监控程序:PerfMon Server Agent 6)Run起来 7)scene1:上个接口的返参作为下个接口入参 8)scene2:单接口下用户访问商品AB的比例控制 or 读写接口混合压测模式下,28原则比例分配 9)对HTTP响应结果进行JSON断言 10)读取CSV文件中的用户账号,密码,cookie等(每个线程执行一次都会取一个新的UID!)

3. 常见压测问题

线程池

  • 核心线程和最大线程数设置太小,导致任务大量排队等待,RT升高; (IO密集型保守设置:corePoolSize=CPU核数*2)
  • 通过实际压测结果调整线程池配置;dubbo默认核心线程数=最大线程数=200、队列长度0、拒绝策略;

代码逻辑复杂度

  • for循环中嵌套bigList.contains(value)方法,复杂度过高,导致CPU飙升;
  • for循环操作DB,和DB交互次数变多,导致RT升高;

数据库DB

  • 查询时没有命中索引,或无索引,导致RT较高;
  • 并发更新单条纪录,导致大量锁等待,RT增加;(MySQL热点key更新最大支持qps1k,实际业务500左右)

缓存Cache

  • Redis和Caffeine中查询缓存为null时,没有放empty值导致缓存穿透,RT增加;

RPC

  • 下游服务性能较差,导致耗时太多;
  • 下游服务dubbo线程池满了,导致大量异常;

JVM

  • OOM(内存泄漏、导出数据时未加锁、异步打印大对象日志)
  • CPU飙高(代码复杂度过高、频繁GC、锁竞争等)

4.JVM调优实战场景

1)CPU飙高:代码复杂度过高

测试demo: jmeter进行压测此接口:

按此步骤进行排查cpu飙高原因排查:

scss 复制代码
top               // 查看各个进程cpu使用情况
top -Hp 11391     // 查看该java进程下所有线程cpu使用情况
printf %x 11405   // 线程ID转换16进制
jstack 11391(进程ID) | grep 2c80(十六进制线程Id)    // 查看堆栈信息
jstack 11391 > out.txt      // 输出thread dump文件
fastthread.io               // 在线分析dump文件

fastthread在线分析dump文件,如下: Refer:jstack命令解析(分析死锁、CPU过高)包教包会 jstack分析性能问题

2)OOM:一次性申请对象太多

项目配置jvm参数: 测试demo: 异常日志: dump文件分析:找内存占用过大的对象->这个对象被谁引用(GC Root)->具体所在的代码

markdown 复制代码
OOM问题有两类最常见的GC Root:
1. 静态变量类,特征为GC Root可追踪到某个静态变量。这类问题有较大概率是缓慢泄漏,
   在发生OOM的时刻没有对大对象进行写入操作的话,无法从线程上找到对应代码。
2. 方法局部变量类,特征为GC Root可追踪到某个线程。
   这类问题发生OOM的时刻大概率可追踪到问题根因的线程。

总结,OOM问题定位思路:

lua 复制代码
配置Jvm参数:PrintGCDetails(打印gc日志)、 HeapDumpOnOutOfMemoryError(生成dump文件)
获取dump文件;
使用内存分析工具对dump文件进行分析:Visualvm、Mat、Arthas等工具;
   // dump文件分析:找内存占用过大的对象->这个对象被谁引用(GC Root)->具体所在的代码
修改验证。

Refer:如何快速定位OOM问题-徐庶FullGC和OOM排查思路结合MAT工具分析OOM问题

相关推荐
Java知识库5 小时前
2025秋招后端突围:JVM核心面试题与高频考点深度解析
java·jvm·程序员·java面试·后端开发
康小庄14 小时前
AQS独占模式——资源获取和释放源码分析
java·开发语言·jvm·spring boot·spring·spring cloud·nio
码不停蹄的玄黓15 小时前
通关JUC:Java并发工具包从入门到精通 | 深度源码解析
java·jvm·spring boot·spring·spring cloud
YuTaoShao1 天前
Java八股文——JVM「内存模型篇」
java·开发语言·jvm
张哈大2 天前
【 java 虚拟机知识 第二篇 】
java·开发语言·jvm·笔记
YuTaoShao2 天前
Java八股文——JVM「垃圾回收篇」
java·开发语言·jvm
@泽栖2 天前
讲讲JVM的垃圾回收机制
java·jvm·面试·八股文
ManageEngine卓豪2 天前
如何有效监控JVM环境,保障应用性能
jvm·虚拟机监控·应用性能监控·java 虚拟机
重庆小透明2 天前
【从零开始学习JVM | 第六篇】运行时数据区
java·jvm·后端·学习
gadiaola2 天前
【JVM面试篇】高频八股汇总——类加载和类加载器
java·jvm·面试