1.从性能工具的原理划分
1.1. Jmeter工具包含4部分
- 资源生成器:用于生成测试过程中服务器、负载机的资源代码。
- 用户运行器:通常是一个脚本运行引擎,根据脚本要求模拟指定的用户行为。
- 报表生成器:根据测试中实时地的数据生成报表,提供可视化的数据显示方式。
- 负载发生器:用于产生负载,通常以多线程或是多进程的方式模拟用户行为。
-------------------------------------------------------------------------------------------------------------------------
Test Plan(测试计划)
- Test Plan:用来描述一个性能测试,包含与本次性能测试所有相关的功能。也就说本的性能测试的所有内容是于基于一个计划的。(相当于一个测试场景)
--------------------------------------------------------------------------------------------------------------------------
2. 测试元件
2.1. 线程组
- setUp Thread Group:一种特殊类型的ThreadGroup的,可用于执行预测试操作。这些线程的行为完全像一个正常的线程组元件。不同的是,这些类型的线程执行测试前进行定期线程组的执行。
- tearDown Thread Group:一种特殊类型的ThreadGroup的,可用于执行测试后动作。这些线程的行为完全像一个正常的线程组元件。不同的是,这些类型的线程执行测试结束后执行定期的线程组。
- Thread Group:通常添加运行的线程。可以看做一个虚拟用户组,线程组中的每个线程都可以理解为一个虚拟用户。线程组中包含的线程数量在测试执行过程中是不会发生改变的。
2.2. 测试片段(Test Fragment)
- 测试片段元素是控制器上的一个种特殊的线程组,它在测试树上与线程组处于一个层级。它与线程组有所不同因为它不被执行除非它是一个模块控制器或者是被控制器所引用时才会被执行。
2.3. 配置元件 (Config Element)
- 用于提供对静态数据配置的支持。如CSV Data Set config可以将本地数据文件形成数据池(Data Pool)
2.4. 定时器(Timer)
- 定时器用于操作之间设置等待时间,等待时间是性能测试中常用的控制客户端QPS I的手端。JMeter 定义了Bean Shell Timer、Constant Throughput Timer、固定定时器等不同类型的Timer
- 如果你不增加延时,Jmeter在短时间内发送多个请求时,可能会压垮服务器。
2.5. 前置处理器(Per Processors)
- 用于在实际的请求发出之前对即将发出的请求进行特殊处理。例如,HTTP URL 重写修复符则可以实现URL重写,当URL中有sessionID一类的session信息时,可以通过该处理器填充发出请求的实际的sessionID。
2.6. 后置处理器(Post Processors)
- 用于对Sampler 发出请求后得到的服务器响应进行处理。一般用来提取响应中的特定数据。
2.7. 断言(Assertions)
- 断言用于检查测试中得到的相应数据等是否符合预期,断言一般用来设置检查点,用以保证性能测试过程中的数据交互是否与预期一致
- 断言可以添加到任何一个Sampler中,它将作用于sampler范围内。如果希望断言只作用于单个sampler,可以在这个sampler中添加子元件断言。
2.8. 监听器(Listener)
- 是用来对测试结果数据进行处理和可视化展示的一系列元件。图行结果、查看果树、聚合报告。都是我们经常用到的元件。注意:这个监听器可不是用来监听系统资源的元件。
- 可以添加到测试中的任何一个地方。它们将从同等级或其下级元件中收集数据。
2.9. 取样器(Smapler)
- 向服务器发送请求,记录响应信息,记录响应时间的最小单元,JMeter 原生支持多种不同的sampler,如 HTTP Request Sampler、FTP Request Sample、TCP Request Sample、JDBCRequest Sampler等,每一种不同类型的sampler可以根据设置的参数向服务器发出不同类型的请求。
2.10. 逻辑控制器(Logic Controller)
- 包括两类无件,一类是用于控制test plan中sampler 节点发送请求的逻辑顺序的控制器,常用的有如果(If)控制器、switch Controller、Runtime Controller、循环控制器等。另一类是用来组织可控制sampler 来节点的,如事务控制器、吞吐量控制器。
3. 元件作用域及执行顺序
3.1元件作用域
作用域原则在jmeter中,元件的作用域是靠测试计划的的树型结构中元件的父子关系来确定的,作用域的原则是:
- 取样器(sampler)元件不和其它元件相互作用,因此不存在作用域的问题。
- 逻辑控制器(Logic Controller)元件只对其子节点中的取样器和逻辑控制器作用。
- 除取样器和逻辑控制器元件外,其他6类元件,如果是某个取样器的子节点,则该元件对I其父子节点起作用。如果其父节点不是取样器,则其作用域是该元件父节点下的其他所有后代节点(包括子节点,子节点的子节点等)
3.2 元件执行顺序
- 配置元件(Config Elements)
- 前置处理器(Pro-processors)
- 定时器(Timers)
- 取样器(Sampler)
- 后置处理器(Post-processors)
- 断言(Assertions)
- 监听器(Listeners)
注意:a)前置处理器、后置处理器和断言等元件功能对取样器作用。因此,如果在它们的作用域内没有任何取样器,则不会被执行;
b)如果在同一作用域范围内有多个同一类型的元件,则这些元件按照它们在测试计划中的上下顺序依次执行。