项目性能优化—使用 JMeter 压测 SpringBoot 项目
我们的压力测试架构图如下:
data:image/s3,"s3://crabby-images/6d248/6d2480f410c3f8661ba1183fde2a486423165690" alt=""
配置 JMeter
在 JMeter 的 bin 目录,双击 jmeter.bat
data:image/s3,"s3://crabby-images/18848/188484b62e9ce8e19f373b97423253374051b607" alt=""
新建一个测试计划,并右键添加线程组:
data:image/s3,"s3://crabby-images/3aa98/3aa981ec7fbbf279b3923c540ce388fe8350e7f6" alt=""
进行配置
data:image/s3,"s3://crabby-images/76f96/76f96e76f2792c8248d7aef7f777758a0715b4d8" alt=""
一共会发生 4 万次请求。
ctrl + s 保存;
添加 http 请求:
data:image/s3,"s3://crabby-images/cc872/cc87243171a5a1a92eb2a8a387f1ebedf888b141" alt=""
配置 http 请求:
data:image/s3,"s3://crabby-images/e1074/e1074adf9a4196552646a17edadeae174dbd7197" alt=""
配置断言,来判断当前请求是否成功:
data:image/s3,"s3://crabby-images/565b5/565b57cfb5a7f5753ce707b03899532f45f93b32" alt=""
正常响应如下:
data:image/s3,"s3://crabby-images/a3cfc/a3cfc56fa891833a2fa380a27d9344ecfb450e81" alt=""
data:image/s3,"s3://crabby-images/1752b/1752ba6ed43b2e10fc85b89699ecfc4dcb702a4b" alt=""
添加断言持续时间
data:image/s3,"s3://crabby-images/55130/551305d445c370e9072af4b30952da01f267693a" alt=""
data:image/s3,"s3://crabby-images/0cba7/0cba75dfb1ab41b0e8bc05ff6ec64eee1d2e7870" alt=""
添加察看结果树:
data:image/s3,"s3://crabby-images/dd699/dd699fdd815a746b2faf493450d0f5248f59a7fc" alt=""
添加汇总报告:
data:image/s3,"s3://crabby-images/b6376/b63766e2b5c5f59c4ebf3646074c49650e733251" alt=""
相似的操作,也添加聚合报告:
data:image/s3,"s3://crabby-images/d3bfc/d3bfcd15a3dc436dd447c0597747ef7c2af7c6cb" alt=""
相似的操作,添加图形结果:
data:image/s3,"s3://crabby-images/1cc5a/1cc5ab703d7675fce784dae52f75878d563e93f4" alt=""
相似的操作,添加汇总图:
data:image/s3,"s3://crabby-images/70f72/70f726e01fbe7ee454e6e61971f33c5fc8ca9ea6" alt=""
发送请求测试
发送请求
data:image/s3,"s3://crabby-images/73635/73635288f36eeb4083f88eb17671851406a7f1cb" alt=""
压力测试结果解析
聚合报告
data:image/s3,"s3://crabby-images/328bf/328bfc04ca9e8446c389bf8713b390b3fcfd9373" alt=""
样本(Sample):发送请求的总样本数量
响应时间(RT):平均值,P90,P95,P99,Min,Max
异常(Error):出现错误的百分比
吞吐量(Throughput):被测试接口的吞吐能力
发送与接收数据量:KB/sec
察看结果树
data:image/s3,"s3://crabby-images/04e65/04e6549c900904fa651c2226a32ab24961fb3157" alt=""
记录了样本中每一次的请求
汇总报告
类似于聚合报告。
线程组配置解析
线程数:用来发送 http 请求的线程数量
线程组常用来模拟一组用户访问系统资源(接口)。如果接口响应速度快,就没必要使用太多线程数,如果响应慢,需要使用很多的线程,来测试接口能扛住的压力。如果客户机没有足够能力模拟较重负载,可以使用 JMeter 分布式压力测试。
Ramp-up(in-seconds):建立全部线程耗时:
代表隔多长时间执行,默认值是 0,0 代表同时并发,用于告知 JMeter 要在多长时间内建立全部线程。
循环次数:循环执行多少次操作
循环次数直接决定整个测试单个线程的执行时间,和整体测试执行时间。
单线程执行时间 = 单请求平均响应时间 * 循环次数
整个测试耗时= 单线程执行时间 + (Ramp-Up - Ramp-UP / 线程数)
JMeter 压测插件
Basic Graphs 主要显示:
Average Response Time 平均响应时间
Active Threads 活动线程数
Successful/Failed Transactions 成功/失败事务数
Additional Graphs 主要显示
Response Codes
Bytes ThroughputConnect Times
Latency
Hits/s
开启插件下载
下载地址: https://jmeter-plugins.org/install/Install/,官网上下载plugins-manager.jar直接在线下载,然后执行在线下载即可。
data:image/s3,"s3://crabby-images/e2744/e274403ba5de6b044e4fa2f439f4d48f63d0f569" alt=""
下载好后放到lib\ext
下;
再把 JMeter 重启;
可以看到插件管理器:
data:image/s3,"s3://crabby-images/097f6/097f6cf61fd14c71362d3ead1a242827259374f4" alt=""
下载如下两个插件:
data:image/s3,"s3://crabby-images/d3fff/d3fff6c91ee08956a4c4d1b004b923395811bfc9" alt=""
安装成功后添加如下三个监听器:
响应时间:jp@gc - Response Times Over Time
活动线程数:jp@gc - Active Threads Over Time
每秒事务数:jp@gc - Transactions per Second
data:image/s3,"s3://crabby-images/99aca/99aca61ea01973e86367a2066b20a29a455b2fcd" alt=""
性能关键指标分析
TPS:每秒的事务数
数字愈大,代表性能越好;
QPS:每秒的查询数量
数字愈大,代表性能越好(1TPS >= 1QPS)
吞吐量:每秒的请求数量
数字愈大,代表性能越好
文章转载自:随机的未知
评论