接口压力测试工具有哪些(jmeter接口压力测试步骤)
jmeter简介
jmeter是啥?
apache jmeter 是apache组织的开放源代码项目,是一个纯java桌面应用,用于压力测试和性能测量。它最初被设计用于web应用测试但后来扩展到其它测试领域。
jmeter有啥用?
apache jmeter可以用于对静态的和动态的资源(文件,servlet,perl脚本,java对象,数据库和查询,ftp服务器或是其它资源)的性能进行测试。jmeter可以用于分析不同压力条件下的总体性能情况。也可以使用jmeter提供的图形化界面,分析性能指标或者在高负载情况下测试你的服务器,脚本,对象。
jmeter和lr有s’m区别?
jmeter安装配置
安装配置号jdk
链接:
https://pan.baidu.com/s/15v8zjglerzvnwdgyhld9jg 提取码: 9×59
jmeter下载地址(以win10为例)
链接:
https://pan.baidu.com/s/1gl7y26rjhj6n6nf214u96a 提取码: rh4y
3.下载后直接点击安装
4.jmeter启动:解压,bin目录下运行apachejmeter.jar进行启动。
jmeter文件目录介绍
bin:可执行文件目录
bin目录文件:
ljmeter.bat:windows的启动文件
l jmeter.log:日志文件
l jmeter.sh:linux的启动文件
l jmeter.properties:系统配置文件
l jmeter-server.bat:windows分布式测试要用到的服务器配置
l jmeter-serve:linux分布式测试要用到的服务器配置
docs:接口文档目录
extras:扩展插件目录
lib:所用到的插件目录,里面全是jar包,jmeter会自动在jmeter_home/lib 和 ext 目录下寻找需要的类
licenses:jmeter证书目录
printable_docs:用户使用手册
jmeter工具组成部分:
资源生成器:用于生成测试过程中服务器、负载机的资源代码。(lr中的vugen)
用户运行器:通常是一个脚本运行引擎,根据脚本要求模拟指定的用户行为。(lr中的controller)
报表生成器:根据测试中实时地的数据生成报表,提供可视化的数据显示方式。(lr中的analysis)
负载发生器:用于产生负载,通常以多线程或是多进程的方式模拟用户行为。(lr中loadgenerators)
test plan (测试计划):用来描述一个性能测试,包含与本次性能测试所有相关的功能。也就说本的性能测试的所有内容是于基于一个计划的。(相当于lr的一个测试场景)
threads (users)线程 用户
a. setup thread group
一种特殊类型的threadgroup的,可用于执行预测试操作。这些线程的行为完全像一个正常的线程组元件。不同的是,这些类型的线程执行测试前进行定期线程组的执行。类似lr的init( )
2) teardown thread group.
一种特殊类型的threadgroup的,可用于执行测试后动作。这些线程的行为完全像一个正常的线程组元件。不同的是,这些类型的线程执行测试结束后执行定期的线程组。类似于lr中的end( )
3)threadgroup(线程组).
这个就是我们通常添加运行的线程。可以看做一个虚拟用户组,线程组中的每个线程都可以理解为一个虚拟用户。线程组中包含的线程数量在测试执行过程中是不会发生改变的。类似lr的action()
测试片段(test fragment)
测试片段元素是控制器上的一个种特殊的线程组,它在测试树上与线程组处于一个层级。它与线程组有所不同,因为它不被执行,除非它是一个模块控制器或者是被控制器所引用时才会被执行。
以下是线程组的8类可执行元件
1.配置元件(config element)
配置元件(config element)用于提供对静态数据配置的支持。如csv data set config 可以将本地数据文件形成数据池(data pool)。
2.定时器(timer)
定时器(timer)用于操作之间设置等待时间,等待时间是性能测试中常用的控制客户端qps的手端。类似于loadrunner里面的“思考时间”。jmeter 定义了bean shell timer、constant throughput timer、固定定时器等不同类型的timer。
3.前置处理器(per processors)
用于在实际的请求发出之前对即将发出的请求进行特殊处理。例如,http url重写修复符则可以实现url重写,当url中有sessionid 一类的session信息时,可以通过该处理器填充发出请求的实际的sessionid 。
4.后置处理器(postprocessors)
用于对sampler 发出请求后得到的服务器响应进行处理。一般用来提取响应中的特定数据(类似loadrunner测试工具中的关联概念)。
断言(assertions)
断言用于检查测试中得到的相应数据等是否符合预期,断言一般用来设置检查点,用以保证性能测试过程中的数据交互是否与预期一致。
监听器(listener)
是用来对测试结果数据进行处理和可视化展示的一系列元件。图行结果、查看结果树、聚合报告。都是我们经常用到的元件。注意:这个监听器可不是用来监听系统资源的元件。
jmeter有两种类型的控制器:取样器(sample)和逻辑控制器(logic controller),用这些原件来驱动处理一个测试。
取样器(sample)
取样器(sample)是性能测试中向服务器发送请求,记录响应信息,记录响应时间的最小单元,jmeter原生支持多种不同的sampler ,如 httprequest sampler 、 ftp request sample 、tcp request sample 、jdbcrequest sampler 等,每一种不同类型的 sampler 可以根据设置的参数向服务器发出不同类型的请求。
逻辑控制器
逻辑控制器,包括两类无件,一类是用于控制test plan 中sampler 节点发送请求的逻辑顺序的控制器,常用的有 如果(if)控制器 、switch controller 、runtime controller、循环控制器等。另一类是用来组织可控制 sampler 来节点的,如 事务控制器、吞吐量控制器。
jmeter脚本录制
1.jmeter脚本录制
http请求+查看结果树
代理服务器操作步骤
创建一个线程组(右键点击“测试计划”->“添加”->“线程组”)
创建一个http代理服务器(右键点击“工作台”->“添加”->“非测试元件”->“http代理服务器”)
tip http服务器代理设置——分组详解
l 不对样本分组:所有请求全部罗列
l 在组间添加分隔:加入一个虚拟的以分割线命名的动作。
l 每个组放入一个新的控制器:执行时按控制器给输出结果
l 只存储每个组的第一个样本:保存对于一次url请求。
设置完后要启动代理服务器,录制完成后记得关闭,
ie->“internet属性”->“连接”->“局域网设置”
在浏览器里对指定的页面进行访问。录制完成后,把浏览器的代理服务器勾去掉。
2.badboy 脚本录制
badboy是一个强大的工具,旨在帮助测试和开发复杂的动态应用。badboy包括一个简单而全面的捕获/回放界面,强大的负载测试的支持,详细的报告图表等等,从而使web测试和开发变得更加容易.
关于录制时的脚本错误提示访问者所使用的浏览器不能完全支持页面里的脚本,形成“脚本错误”。遇到“脚本错误”时一般会弹出一个非常难看的脚本运行错误警告窗口,而事实上,脚本错误并不会影响网站浏览,因此这一警告可谓多此一举。要关闭警告则可以在浏览器的工具菜单选择internet选项,然后单击高级属性页。进入到浏览标签,并选中“禁止脚本调试”复选框,以后你就不会再收到这些警告了。
脚本录制完成后,导出为 export to jmeter (见脚本haosou.bx)
badboy检查点与参数化
检查点设置:选择要检查的文字,然后在tools>step1里添加断言,再回放
参数化:在请求搜索关键字的部分进行参数化,找到请求的字段,然后对其值进行设定。参数化替换${参数名称} 最后在step 1属性里进行设置回放次数和参数化的变量名称。最后检查点也要进行参数化,以及整个step 属性的设置
jmeter元件作用域和执行顺序
1.元件作用域
8类可被执行的元件(测试计划与线程组不属于可执行元件),这些元件中,取样器(sampler)是典型的不与其它元件发生交互作用的元件,逻辑控制器只对其子节点的取样器有效,而其它元件(配置元件 、定时器、断言、监听器、)需要与取样器(sampler)等元件交互。
在jmeter中,元件的作用域是靠测试计划的的树型结构中元件的父子关系来确定的,作用域的原则是:
• 取样器(sampler)元件不和其它元件相互作用,因此不存在作用域的问题。
• 逻辑控制器(logic controller)元件只对其子节点中的取样器和逻辑控制器作用。
• 除取样器和逻辑控制器元件外,其他6类元件,如果是某个取样器的子节点,则该元件对其父子节点起作用。如果其父节点不是取样器 ,则其作用域是该元件父节点下的其他所有后代节点(包括子节点,子节点的子节点等)。
最后一个查看结果树的作用域为循环控制器下面所有取样器的结果
2.元件执行顺序
(1)配置元件(config elements )
(2)前置处理程序(per-processors)
(3)定时器(timers )
(4)取样器(sampler)
(5)后置处理程序(post-processors)
(6)断言(assertions)
(7)监听器(listeners)
关于执行顺序,有两点需要注意:
前置处理器、后置处理器和断言等元件功能对取样器作用,因此,如果在它们的作用域内没有任何取样器,则不会被执行。
如果在同一作用域范围内有多个同一类型的元件,则这些元件按照它们在测试计划中的上下顺序依次执行。