1.1 测试环境准备
数据库:Oracle 11g,库名:orcl;
Jmeter:jmeter-5.1.1安装在win10系统下(到 http://jmeter.apache.org/ 下载JMeter压缩包,无需安装解压即可,点击bin目录下的jmeter.bat文件即可运行Jmeter)
JDBC驱动:找到ojdbc 14.jar并将其复制粘贴到D:\Program Files\apache-jmeter-5.1.1\lib目录下
1.2 测试计划
打开测试计划,添加JDBC驱动:
1.3 线程组
添加一个线程组,并配置页面。
在取样器错误后要执行的动作:在线程内的采样器失败后,接下来做什么。
1) 继续:继续执行接下来的操作;
2) Start Next Loop:忽略错误,执行下一个循环;
3) 停止线程:退出该线程(不再进行此线程的任何操作);
4) 停止测试:等待当前执行的采样器结束后,结束整个测试;
5) Stop Test Now:直接停止整个测试。
线程属性(5个设置项)
1) 线程数:模拟的用户数量;
2) Ramp-up Period(in seconds):达到指定线程数所需要的时间。举例:线程数设置为50,此处设置为5,那么每秒启动的线程数 = 线程数50/5 = 10;
3) 循环次数:选中“永远”,则一直循环下去;
4) Delay Thread creation until needed:(延迟创建线程直到需要):当线程需要执行的时候,才会被创建。如果不选择这个选项,那么,在计划开始的时候,所有需要的线程就都被创建好了;
5) 调度器:详见下文“调度器配置”。
调度器配置:全部都在“调度器”复选框被选中的前提下,下面的选项才会生效。
1) 持续时间(秒):在此选项填入N,说明这个计划,从某个开始时间算起,执行N秒后结束。(会忽略“结束时间”的选项);
2) 启动延迟(秒):在此选项填入N,手动点击开始执行计划,然后延迟N秒后,计划才真正开始执行。(会忽略“启动时间”的选项);
3) 启动时间:当点击开始测试时,将等到此处填写的启动时间,然后真正开始测试;
4) 结束时间:当开始测试时,将等到指定的开始时间开始测试,然后会停在此处填写的时间点结束。
1.4 JDBC Connection Configuration
添加配置元件“JDBC Connection Configuration”,并配置页面。
Variable Name Bound to Pool:
Variable Name:数据库连接池的变量名,之后JDBC request可以通过选择不同的连接池名来选择不同的数据库连接。变量名不能重名。
Connection Pool Configuration:JDBC连接池配置,一般使用默认值就可以。
1) Max Number of Connections:数据池允许的最大连接数,通常该值设置为0,意思是每个线程都使用单独的数据库连接,例如,配置在两个线程间不共享。如果你确实想共享连接池,那么最大连接数应当和线程数一样,以便线程不用互相等待;
2) Max Wait (ms):在连接池中取回连接的最大等待时间,如果超过改时间,将抛出一个错误;
3) Time Between Eviction Runs (ms):数据库空闲连接的回收时间间隔。回收时,会将将空闲连接物理性的关闭掉。若为非正数,则空闲连接回收器不停运行;
4) Auto Commit:自动提交。有三个选项,true、false、编辑(自己通过jmeter变量值设置)。选择true后, 每条sql语句就是一个事务,执行结束后会自动提交;否则不会提交,需要自己手动提交;
5) Transaction Isolation:数据库事务隔离的级别设置,有6个选项(对JMX加解密):TRANSACTION_NODE:事务节点;TRANSACTION_READ_UNCOMMITTED:事务未提交读;TRANSACTION_READ_COMMITTED:事务已提交读; TRANSACTION_SERIALIZABLE:事务序列化;DEFAULT:默认;TRANSACTION_REPEATABLE_READ:事务重复读;编辑。
Connection Validation by Pool,连接池有效性验证配置部分:这是Jmeter用来检验数据库连接是否有效的一种机制,超过5秒没有使用的话,就会用validation query去测试下这个连接是否有效,一般使用默认就可以。
1) Test While Idle:是否在空闲时进行连接有效性验证。Validation Quary被用来验证连接的有效性;
2) Soft Min Evictable Idle Time(ms):数据库连接池中的连接至少闲置多久才能被回收。额外的条件是,在连接池中至要保留有minIdle个连接
3) Validation Query:一个验证数据库仍然响应的简单查询语句。默认是JDBC驱动的 ‘isValid()’ 方法,它适合于很多数据库。可以通过jmeter.properties中jdbc.config.check.query属性设置默认的验证sql语句,有10个选项:Hsqldb select 1 from INFORMATION_SCHEMA.SYSTEM_USERS;Oracle select 1 from dual;DB2 select 1 from sysibm.sysdummy1;MySQL select 1;Microsoft SQL Server (MS JDBC driver) select 1;PostgreSQL select 1;Ingres select 1;Derby values 1;H2 select 1;Firebird select 1 from rdb$database。
Database Connection Configuration,数据库连接配置部分。
1) Database URL: 数据库的连接字符串;
2) JDBC Driver class:驱动程序类的完全限定名;
3) Username:连接数据库的合法用户名;
4) Password:用户对应的口令。
1.5 JDBC Request
添加取样器“JDBC request”,并配置页面。
Variable Name Bound to Pool:
Variable Name:数据库连接池的名字,需要与JDBC Connection Configuration的Variable Name Bound Pool名字保持一致。
SQL Query:
1) Query Type:JDBC Request可以发送的请求类型,目前有10类:Select Statement;Update Statement - use this for Inserts and Deletes as well; Callable Statement;Prepared Select Statement;Prepared Update Statement - use this for Inserts and Deletes as well;Commit;Rollback;Autocommit(false);Autocommit(true);Edit - this should be a variable reference that evaluates to one of the above;
2) Query:填写的sql语句,未尾不要加“;”;
Parameter values:参数值。
Parameter types:参数类型,(比如varchar、tinyint(m)、smallint(m) )。
Variable names:保存sql语句返回结果的变量名。
Result variable name:创建一个对象变量,保存所有返回的结果。
Query timeout:查询超时时间。
Handle result set:定义如何处理由callable statements语句返回的结果,有四个选项:Store as String;Store as Object;Count Records;编辑。
1.6 HTTP请求默认值
该组件可以为我们的http请求设置默认的值。假如,我们创建一个测试计划有很多个请求且都是发送到相同的server,这时我们只需添加一个 Http request defaults组件并设置“Server Name or IP”,然后添加多个http请求且不设置”server name or ip”,这些http请求会默认使用Http request defaults组件设置的值。
1.7 BeanShell 后置处理程序
添加后期处理器BeanShell PostProcessor,用来把查询的结果显示在log上。如果不需要设置postprocessor观察数据,可以直接添加监听器运行。
在利用jmeter进行接口测试或者性能测试的时候,我们需要处理一些复杂的请求,此时就需要利用bean shell脚本了,Bean Shell是一种完全符合Java语法规范的脚本语言,并且又拥有自己的一些语法和方法,所以它和java是可以无缝衔接的。bean shell本身自带的一些内置变量和一些方法。JMeter在其Bean Shell中内置了变量,用户通过这些变量与JMeter进行交互。
1) log 打印日志,写入信息到jmeber.log文件。
2) SampleResult 获取SampleResult对象,能通过这个对象获取想要的信息。
3) Response 获取Response对象,能通过这个对象获取响应信息。
4) Failure 查看接口调使用能否成功,假如返回false是成功的,true是失败的。
5) FailureMessage 失败信息,没有设置的时候失败信息是空的,能set这个信息。
6) ResponseData 获取response body类型是byte[]。
7) ResponseCode 返回接口code成功是200。
8) ResponseMessage 获取msg成功是OK。
9) ResponseHeaders 获取接口服务端返回的头部信息。
10) RequestHeaders 获取用户端请求的头部信息。
11) SampleLabel 获取接口请求的名称。
12) SamplerData 获取请求的url和body。
13) ctx代表上下文信息,能直接用。
14) vars即JMeterVariables,操作jmeter变量,这个变量实际引用了JMeter线程中的局部变量容器(本质上是Map),常用方法:
a) vars.get(String key):从jmeter中获得变量值;
b) vars.put(String key,String value):数据存到jmeter变量中;
15) prev 获取前面的sample返回的信息,常用方法:
a) getResponseDataAsString():获取响应信息。
b) getResponseCode() :获取响应code。
2 JDBC连接测试
2.1 测试场景
场景描述:
通过将线程数分别设置为100、200、300,以实现对100个用户同时对JDBC发出查询指令,200个用户同时对JDBC发出查询指令,300个用户同时对JDBC发出查询指令的模拟。
2.2 测试用例
平均值:总运行时间除以发送到服务器的请求数;
中间值:代表时间的数字,有一半的服务器响应时间低于该值而另一半高于该值;
偏离:服务器响应时间变化、离散程度测量值的大小,或者,换句话说,就是数据的分布。
分析:
在此情况下数据库管理系统服务器的平均值为588,中间值为545,响应时间差异大。响应性能不稳定。
c) 聚合报告
Label:数据请求方式,图上是数据库连接;
#samples:向服务器发送的请求数目;
Average:总运行时间除以发送到服务器的请求数;
Median:图形报表中的中间值,是代表时间的数字,有一半的服务器响应时间低于该值而另一半高于该值;
90%line:是指90%请求的响应时间比所得数值还要小;
95%line:是指95%请求的响应时间比所得数值还要小;
99%line:是指99%请求的响应时间比所得数值还要小;
Min:是代表时间的数字,是服务器响应的最短时间;
Max: 是代表时间的数字,是服务器响应的最长时间;
Error%:请求的错误百分比;
Throughput:图形报表中的吞吐量,这里是服务器每单位时间处理的请求数,注意查看是秒或是分;
KB/sec:是每秒钟请求的字节数。
分析:
本次测试场景运行100线程,平均响应时间=558ms,统计意义上的响应时间中值=545ms,所有线程中90%的线程响应时间都小于1000ms,所有线程中95%的线程响应时间都小于1064ms,所有线程中99%的线程响应时间都小于1086ms,响应最小时间=20ms,响应最大时间 =1122ms,出错率 = 0,吞吐量为每秒84个请求。
2.3.2 200个用户同时对JDBC发出查询指令
a) 察看结果树
b) 图形结果
分析:
在此情况下数据库管理系统服务器的平均值为102,中间值为3,响应时间差异较大。响应性能较不稳定。相应的,响应时间有所增加。
c) 聚合报告
分析:
本次测试场景运行200线程,平均响应时间=102ms,统计意义上的响应时间中值=3ms,所有线程中90%的线程响应时间都小于356ms,所有线程中95%的线程响应时间都小于435ms,所有线程中99%的线程响应时间都小于514ms,响应最小时间=1ms,响应最大时间 =677ms,出错率 = 0,吞吐量为每秒163.4个请求。
2.3.3 300个用户同时对JDBC发出查询指令
a) 察看结果树
b) 图形结果
分析:
在此情况下数据库管理系统服务器的平均值为2,中间值为2,响应时间明显减小。响应性能稳定。随着用户的增加,响应时间变长。
c) 聚合报告
分析:
本次测试场景运行300线程,平均响应时间=2ms,统计意义上的响应时间中值=2ms,所有线程中90%的线程响应时间都小于3ms,所有线程中95%的线程响应时间都小于3ms,所有线程中99%的线程响应时间都小于3ms,响应最小时间=1ms,响应最大时间 =5ms,出错率 = 0,吞吐量为每秒235.8个请求。
3 测试结果
根据表中数据可知,随着用户请求数量的增加,数据库服务器的每分钟处理请求数即吞吐量也在逐步增加,平均响应时间大幅减少。
经过分析可得出以下结论:
数据库服务器的系统性能随着用户数量的增加而大大提高,此数据库服务器的系统性能良好,测试的数值在其承受范围内。