Jmeter各部件的作用

JMeter主要组件介绍

1.测试计划(Test Plan)是使用 JMeter 进行测试的起点,它是其它 JMeter 测试元件的容器。

2.线程组(Thread Group)代表一定数量的并发用户,它可以用来模拟并发用户发送请求。

3.取样器(sampler)定义实际的请求内容,被线程组包含,我们主要用HTTP请求。

4.监听器(Listener)

5.逻辑控制器(Logic Controller)

6.断言(Assertions)

7.配置元件(Config Element)

8.前置处理器(Pre Processors)和后置处理器(Post Processors)

9.定时器(Timer)

JMeter主要组件介绍-测试计划

1.测试计划(Test Plan)是使用 JMeter 进行测试的起点,它是其它 JMeter 测试元件的容器。

2.名称:你可以为你的测试计划取一个有意义的名字。

3.注释:对测试计划的注释。

4.用户定义的变量:用户可以自己定义变量,在用到此变量的时候直接用${变量名}引用即可。例:变量名=url,值=http://www.baidu.com,在需要http://www.baidu.com时直接用${url}即可。

5.Add directory or jar to classpath:向类路径即%JMETER-HOME%\lib中添加目录及jar包。

JMeter主要组件介绍-线程组

1.名称:为线程组起名字。

3.线程属性-线程数:设置发送请求的用户数目 ,即并发数。

4.线程属性-Ramp-Up Period(in second):线程间的时间间隔,单位是秒。即所有线程在多少时间内启动。

5.线程属性-循环次数:请求的重复次数,如果选择后面的forever(默认),那么 请求将一直继续,如果不选择forever,而在输入框中输入数字,那么请求将重复指定的次数,如果输入1,那么请求将执行一次,如果是0,会出现问题。

5.调度器配置-启动时间:测试计划什么时候启动,启动延迟会覆盖它。

6.调度器配置-结束时间:测试计划什么时候结束,持续时间会覆盖它。

7.调度器配置-持续时间:测试计划持续多长时间,会覆盖结束时间。

8.调度器配置-启动延迟:测试计划延迟多长时间启动,会覆盖启动时间。

JMeter主要组件介绍-取样器(HTTP请求)

1.名称:HTTP请求的名字。

2.Web服务器-服务器名称或IP、端口号,脚本录制时自动添加,也可以使用“用户自定义变量”。

3.HTTP请求:用默认值即可。

4.同请求一起发送参数:请求中的参数、值可以在此设置,需要用到参数化及动态数据关联,我们在后面专门介绍。

5.同请求一起发送文件:我可以制定同请求一起发送哪个文件。

6.其他任务包括:从HTML文件中获取所有内含的资源、用作监视器、Embedded URLs must match。

JMeter主要组件介绍-监听器

1.监听器(Listener)负责收集测试结果,同时也被告知了结果显示的方式。

我们常用的包括:聚合报告、查看结果树、用表格查看结果,都支持将结果数据写入文件。

其他的添加上去看看就行。聚合报告前面我们介绍过,后面是查看结果树和用表格查看结果的截图。

JMeter主要组件介绍-监听器(用表格查看结果)

JMeter主要组件介绍-逻辑控制器

1.逻辑控制器(Logic Controller)可以自定义JMeter发送请求的行为逻辑,它与Sampler结合使用可以模拟复杂的请求序列。

v循环控制器可以设置请求的循环次数或永远循环(如果选中永远的话)。

v事务控制器可以将多个请求放在同一个事务中。如果选中Gegerate parent sample,则聚合报告中只显示事务控制器的数据,而不会显示其中的各个请求的数据,反之则全部显示。

JMeter主要组件介绍-断言

1.断言(Assertions)可以用来判断请求响应的结果是否如用户所期望的。它可以用来隔离问题域,即在确保功能正确的前提下执行压力测试。这个限制对于有效的测试是非常有用的。

JMeter主要组件介绍-配置元件

1.配置元件(Config Element)维护Sampler需要的配置信息,并根据实际的需要会修改请求的内容。我们主要在参数化中用到CSV Data Set Config

JMeter主要组件介绍-前置处理器和后置处理器

1.前置处理器(Pre Processors)和后置处理器(Post Processors)负责在生成请求之前和之后完成工作。前置处理器常常用来修改请求的设置,后置处理器则常常用来处理响应的数据。我们主要在动态关联中用到后置处理器的正则表达式提取器。

JMeter主要组件介绍-定时器

1.定时器(Timer)负责定义请求之间的延迟间隔。

参数化设置

1.在我们的测试计划中我们使用的都是HTTP请求,在HTTP请求中常常会提交一些参数,我们为了不想在每一次请求中都使用相同的参数值,就要想办法让每一次请求的参数的值都是不一样的,我们就需要进行参数化设置,这里我们介绍两种参数化设置的方法。

一种是利用函数助手中的_Random函数进行参数化设置;

一种是利用配置元件中的CSV Data Set Config进行参数化设置

2.JMeter中有一个函数助手的功能,里面内置了多个函数,我们可以利用其中的_Random函数来进行请求中的参数化设置。

v在JMeter中选择“选项-函数助手对话框”打开函数助手对话框。

v选择一个功能_Random。

v设定最小值为1。

v设定最大值为100。

v函数名称设为func1。

v点击生成将生成一个引用字符串${_Random(1,100,func1},在需要的请求参数中拷贝该字符串即可。

v其中函数名称用来在引用中作区别,即我们可以设定不同的名称在不同的地方引用同一个函数的功能。

v例如:我们生成了两个串${_Random(1,100,func1)}、 ${_Random(1,100,func2)},在添加图书的请求中,我们在bookName的参数值中引用${_Random(1,100,func1)},在bookConcern的参数值中应用${_Random(1,100,func2)},见截图,这样测试运行时不同的线程将产生不同的bookName和bookConcern。

参数化设置-CSV Data Set Config(1)

v在线程组上点击右键选择添加-配置元件-CSV Data Set Config,打开CSV Data Set Config。

vFilename文件名:即参数化要引用的文件名。这里是d:\number.txt

vFile encoding文件编码:可以不填。

vVariable Names(comma-delimited)变量名(用逗号分割):多个变量可以引用同一个文件,用逗号分割。这里是num1,num2

vDelimiter(use ‘\t’ for tab):参数文件中多个变量值的分隔符,\t表示用tab键分割,默认是逗号。

vRecycle on EOF?:结束后是否循环?默认是True.

vNumber.txt文件内容见截图。

v在添加图书的请求中,我们在bookName的参数值中引用${num1},在bookConcern的参数值中应用${num2},见截图,这样测试运行时不同的线程将产生不同的bookName和bookConcern。

动态数据关联

1.在HTTP请求的参数中经常会遇到一些参数的值是从服务器相应的动态数据,这些数据需要进行关联才能使得每一次请求都能成功得被服务器接受,在JMeter中采用正则表达式提取器来获取这些动态的数据。

2.正则表达式允许用户从服务器响应中获取数据,作为一个后置处理器,正则表达式提取器会在每一个请求执行后再执行,正则表达式提取请求的参数值,产生模板字符串,并将结果保存到给出的变量中。

动态数据关联(1)-正则表达式提取器

1.在HTTP请求的参数中经常会遇到一些参数的值是从服务器相应的动态数据,这些数据需要进行关联才能使得每一次请求都能成功得被服务器接受,在JMeter中采用正则表达式提取器来获取这些动态的数据。比如我们想要获得从服务器相应的TOKEN,就可以使用下面的正则表达式提取器。

动态数据关联(2)

v使用时就可以使用${token_g1}来表示获取到的TOKEN值。如下图:

使用命令行运行JMeter脚本

vJMeter -n -t my_test.jmx -l log.jtl

v-n告知JMeter采用非图形化运行JMeter脚本

v-t指定要运行的脚本文件

v-l指定保存执行结果的文件名

v执行命令前要检查当前目录是否是%JMeter_Home%\bin 目录;

v如果 JMeter 脚本不在当前目录,需要指定完整的路径;如果要把执行的结果保存在其他地方也要指定完整的路径。

利用XSLT分析JMeter结果文件(1)

1.将结果文件的扩展名改为xml,例:将log.jtl改为log.xml。

2.在log.xml的文件头

<?xml version="1.0" encoding="UTF-8"?>

<testResults version="1.2">

中添加

<?xml-stylesheet type=“text/xsl” href=“jmeter-results-report.xsl” ?>

使之变成

<?xml version="1.0" encoding="UTF-8"?>

<?xml-stylesheet type="text/xsl" href="jmeter-results-report.xsl" ?>

<testResults version="1.2">

其中href指定xsl文件的路径,如果与xml文件在同一目录,则只写文件名即可,否则要写明详细路径。

利用XSLT分析JMeter结果文件(2)

1.将修改后的xml文件用浏览器打开即可得到统计结果:

JMeter中进行分布式测试

作为一个纯 JAVA 的GUI应用,JMeter对于CPU和内存的消耗还是很惊人的,所以当需要模拟数以千计的并发用户时,使用单台机器模拟所有的并发用户就有些力不从心,甚至还会引起JAVA内存溢出的错误。不过,JMeter也可以像 LoadRunner 一样通过使用多台机器运行所谓的代理来分担负载产生器自身的压力,并借此来获取更大的并发用户数,我们只需手动配置一下即可。

v1、在所有期望运行JMeter作为 负载产生器的机器上安装JMeter,并确定其中一台机器作为 控制器,其他的机器作为 代理。然后运行所有 代理 机器上的JMeter-server.bat文件—假定我们使用两台机器172.20.80.47和172.20.80.68作为 代理;

v2、在Controller 机器的JMeter安装目录下找到 bin 目录,再找到 jmeter.properties 这个文件,使用记事本或者其他文字编辑工具打开它;

v3、在打开的文件中查找“remote_hosts=”这个字符串,你可以找到这样一行“remote_hosts=127.0.0.1”。其中的 127.0..0.1 表示运行JMeter代理的机器,这里需要修改为“remote_hosts=172.20.80.47,172.20.80.68”;

v4、保存文件,并重新启动控制器机器上的JMeter,并进入启动 ->远程启动菜单项。就会看到我们刚才添加的两个代理的地址,选中即可运行,如果想同时启动所有代理,选择远程全部启动即可。

要进行分布式测试代理机器上需要添加环境变量,即添加用户变量JMETER_HOME=d:\jmeter,系统变量中的path中添加d:\jmeter\bin(假设jmeter放在d盘根目录下)。

运行Jmeter进行测试(4)-聚合报告详解

vLabel:每个 JMeter 的 element (例如 HTTP Request )都有一个 Name 属性,这里显示的就是 Name 属性的值

v#Samples:表示你这次测试中一共发出了多少个请求,如果测试计划模拟10个用户,每个用户迭代10次,这里就会显示100

vAverage:平均响应时间 — 默认情况下是单个 Request 的平均响应时间,当使用了事务控制器时,也可以以事务为单位显示平均响应时间

vMedian:中位数,也就是 50 %用户的响应时间

v90% Line: 90 %用户的响应时间

vMin:最小响应时间

vMax:最大响应时间

vError%:错误率,本次测试中出现错误的请求的数量 / 请求的总数

vThroughput:吞吐量 —— 默认情况下表示每秒完成的请求数( Request per Second )

vKB/Sec:每秒从服务器端接收到的数据量

原文地址:https://www.cnblogs.com/loved-wangwei/p/8992849.html

时间: 2024-11-22 19:36:02

Jmeter各部件的作用的相关文章

【转】JMeter学习(二十六)逻辑控制器

JMeter中的Logic Controller用于为Test Plan中的节点添加逻辑控制器. JMeter中的Logic Controller分为两类:一类用来控制Test Plan执行过程中节点的逻辑执行顺序,如:Loop Controller.If Controller等:另一类则与节点逻辑执行顺序无关,用于对Test Plan中的脚本进行分组.方便JMeter统计执行结果以及进行脚本的运行时控制等,如:Throughput Controller.Transaction Controll

综合布线产品中的传输部件和保障部件

综合布线系统产品,其最重要的一点就是在于提高整个系统的长期可靠性,美观性.易管理性.为此,产品构成就必须遵循以下原则,即隐蔽在吊顶.墙面和地坪中的各种线缆应不易让人或其他事物碰到:而用户经常可能碰到的缆线则可以保证随时可以更换,而这两段线缆交接处的节点必须可靠.美观且易管理. 在这样的构思中,隐蔽区域用的单股双绞线与暴露区域使用的多股双绞线通过模块互连,这些模块隐蔽安装在墙面的面板上,这时的面板发挥多个作用:一是装卸模块,使模块能够稳定固定在墙面上:二是保护模块所连接的线缆,使人们无法在不拆卸面

磁盘的组成

  磁盘的组成 作者:Jack.X 归档:学习笔记 2017/4/10 磁盘 第1章 知识扩展: 1.1 如何同时创建多个用户并设置规定的密码 如何批量创建stu01到stu10,10个用户然后修改密码123456 [第一个里程碑]:创建一个用户并修改密码 [[email protected] ~]# useradd stu01 [[email protected] ~]# echo 123456 |passwd --stdin stu01Changing password for user s

深入浅出UML类图

在UML 2.0的13种图形中,类图是使用频率最高的UML图之一.Martin Fowler在其著作<UML Distilled: A Brief Guide to the Standard Object Modeling Language, Third Edition>(<UML精粹:标准对象建模语言简明指南(第3版)>)中有这么一段:“If someone were to come up to you in a dark alley and say, 'Psst, wanna

ADO.NET数据库

ASP.NET提供了ADO.NET技术,它是ASP.NET应用程序与数据库进行交互的一种技术. ADO.NET技术把对数据库的操作分为几个步骤,并为每个步骤提供对象来封装操作过程,从而使对数据库的操作变得简单易行. ADO.NET组件通过以下两个主要的组件将数据访问与数据处理分离: 1. ADO.NET体系结构的一个核心元素是.NET数据提供程序,它是专门为数据处理以及快速地只进.只读访问数据而设计的组件,包括Connection.Command.DataReader和DataAdapter对象

UML 系列

Bug管理系统UML2.0建模实例(四) 3.3 顺序图(实现模型)       在系统设计与实现阶段我们也可以使用顺序图进行建模,此时通过顺序图可以明确表示系统设计中对象之间的交互,考虑到具体系统实现,对象之间通过方法调用传递消息.在BMS系统中,对每个用例均可以绘制基于实现模型的顺序图.由于篇幅关系,未将每个用例的顺序图一一列举.图3-5.3-6分别是用例“登录”和“提交bug信息”的实现模型顺序图.图3-5用例“登录”顺序图(实现模... 2013-12-16 23:15 阅读(2771)

开发人员应该知道5个设计技巧

优秀的编码和优秀的UI设计之间是相辅相成的.不幸的是,视觉设计能力偏弱的人通常会觉得自己缺乏天赋,换句话说,就是人们要么觉得自己具有出众的美学天赋,要么就是这方面的白痴.对这个说法,我可不敢苟同. 如果你在一个小团队里面身兼数职,却又没有多少美学基础.又或者你觉得你们的项目在视觉上还有更多发挥的空间,那么这篇文章就是写给你的.蓝蓝设计将谈到传统的5个消除丑陋艺术设计的元素和原则(或者至少能够进行一定程度的掩盖) 1.来点留白 大多数的开发者并不在意添加空白的像页边距,填充,行高,或者其他任何增加

《转载》Java EE启示录

前言 最近的这段时间一直在学习Java EE,刚刚完成了从0到1的蜕变,所以顺便整理一下我所了解到的Java EE,给刚入门学习的新人一些头绪,而所谓"启示录",就是这个意思. 一.Java EE是什么? Java EE(Java Enterprise Edition)是一种企业级应用的软件架构,同时是一种思想,一套规范. 二.Java EE的发展史 Java Enterprise Edition的发展不知不觉已经12年了,不知道大家有没留意,一开始,Java Enterprise E

x86、i386、i486、i586、i686和x86_64

x86.i386.i486.i586.i686和x86_64 1.386与686 i386—几乎所有的X86平台,不论是旧的pentum或者是新的pentum-IV与K7系统CPU,都可以正常工作,i指得是Intel兼容的CPU,至于386就是CPU的等级. i586—就是586等级的计算机,包括pentum第一代MMX CPU,AMD的K5,K6系统CPU(socket7插脚)等CPU都是这个等级. i686—pentum 2 以后的Intel系统CPU及K7以后等级的CPU都属于这个686等