现在企业做接口性能测试,大多还是会用JMeter,而JMeter是用java开发的、开源项目,所以,JMeter依赖java运行环境。目前,jdk已经发布了多个新版本,主推的是jdk17。推荐它的一个重要原因是,jdk17开发的项目性能,要比jdk8快很多。
作为性能测试人员,我们可能左右不了公司java项目开发用的jdk版本,但是,在使用JMeter的时候,可以考虑使用不同版本的jdk。如果JMeter的运行性能越好,单位时间内对被测对象发起的请求数越多,那么,对被测对象造成的压力就会更大,就能越真实的测试出被测对象的性能。
哪,我们应该选择用jdk17吗?
作为测试人员,总是有一个猜想之后,就要用实际性能来验证,那么,接下来,我们就来准备环境,实测验证一下。
- 操作系统。日常大家用的比较多的是windows系统,所以,我们准备一台windows10电脑(最好是没有安装其他软件)。
- 安装jdk。从网络上下载jdk8和jdk17的安装包,并把他们都放到准备好的电脑中。一台电脑,是允许安装多个jdk版本的,所以,可以直接在准备好的电脑中,双击jdk8和jdk17的安装包进行安装。
- 安装JMeter。从JMeter的官网上下载JMeter的zip包,目前最新的是5.5版本。下载后,放到准备好的电脑中,解压。进入JMeter解压后的文件夹的bin文件夹,双击jmeter.bat文件,启动JMeter。
- 编写测试脚本。在JMeter中,添加普通线程组;在线程组下面,添加调试取样器;再添加汇总报告;在添加非测试元件‘显示属性’;保存好脚本。
- 切换JMeter的jdk,进行测试,分析测试结果。首先打开cmd窗口,运行java -version 查看当前系统默认的jdk版本。在JMeter中,点击‘显示属性 > System’,找到里面的‘java.version',确认值与系统的jdk大版本一致。
修改线程组中线程数为50,循环次数勾选‘永远’,勾选‘调度器’,持续时间设置为‘300’秒。
运行脚本,进行性能测试,观察汇总报告中的数据,在测试停止后,点击汇总报告底部的‘保存表格数据’按钮,把数据保存到本地。多次运行脚本,并把多次的汇总报告数据进行保存。
关闭JMeter图形界面,用文本编辑器打开jmeter.bat文件,添加如下信息:
set MINIMAL_VERSION=1.8.0
set JAVA_HOME=C:\Program Files\Java\jdk1.8.0_331
set PATH=%JAVA_HOME%\bin;%PATH%
# 如果要设置为jdk17,MINIMAL_VERSION=17.0 JAVA_HOME=为jdk17的安装路径
指定jmeter运行时使用另外一个jdk版本,保存文件。
双击jmeter.bat,启动JMeter图像界面,打开之前保存的脚本,查看‘属性显示 > System’中java.version的值,确认为你指定的版本。
运行脚本,进行性能测试,保存汇总报告的数据到文件,反复执行多次。
- 数据分析
这是在不同jdk版本下,分别执行5次,收集的数据。从测试结果数据看,在jdk8时,请求的样本总数整体要大一些,吞吐量也要大一些,如下图:
用调试取样器,进行测试,是不会向机器之外的网络发送请求,所以,就相当于测试JMeter自身性能,标准偏差越小,说明JMeter自身处理数据的时间差异越小,越稳定。结果jdk8的标准偏差更小。
所以,整体来说,JMeter做性能测试,jdk8还是比jdk17优秀。不能人云亦云的选择jdk17.