jmeter笔记1

使用 JMeter 分布式性能测试

作为一个纯 JAVA 的GUI应用,JMeter 对于CPU和内存的消耗还是很惊人的,

所以当需要模拟数以千计的并发用户时,使用单台机器模拟所有的并发用户就有些力不从心,

甚至还会引起JAVA内存溢出的错误。不过,JMeter 也可以像 LoadRunner 一样通过使用多台机器运行所谓的 Agent 来分担 Load Generator 自身的压力,并借此来获取更大的并发用户数。

根据 JMeter官方文档的署名,你需要自己完成这个配置,不过不用担心,这将非常简单 ^_^

1.在所有期望运行 JMeter 作为 Load Generator 的机器上安装 JMeter,并确定其中一台机器作为 Controller,其他的机器作为 Agent。

然后运行所有 Agent 机器上的JMeter-server.bat文件——假定我们使用两台机器 192.168.0.1 和 192.168.0.2 作为 Agent;

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

3. 在打开的文件中查找“remote_hosts=”这个字符串,你可以找到这样一行“remote_hosts=127.0.0.1”。其中的 127.0..0.1 表示运行 JMeter Agent 的机器,

这里需要修改为“remote_hosts=192.168.0.1:1664,192.168.0.2:1664”——其中的 1664 为 JMeter 的 Controller 和 Agent 之间进行通讯的默认 RMI 端口号;

4.保存文件,并重新启动 Controller 机器上的 JMeter.bat,并进入 Run -> Remote Start 菜单项。

jmeter试用记录-重要元件介绍

经过脚本的编辑,应该已经接触了不少jmeter的元件了,如“线程组”等。

元件是jmeter的最主要特色,脚本的各种逻辑,运行时各项参数的设置,运行时的监控,都通过把元件加入到测试计划并进行配置来实现,下面是重要元件的介绍。

1、线程组

线程组的概念相当于Loadrunner Controller运行方案中的“VUser组”,右击测试计划,选择“添加”-“线程组”,可以加入一个线程组,加入线程组后,需要设置的参数如下:

线程数--模拟用户的数目(并发运行的线程数目),循环次数--每一个线程循环的次数,Ramp-Up Period -- 所有模拟用户都运行所需要的时间,如果设置10个用户,改值为100s,

则每10s会启动一个用户线程。“调度器”勾上后,还会出现一个定时器,指定启动时间和结束时间,具体看jmeter帮助。

2、控制器

一般来说,一个线程组会有若干个请求(典型的如http请求),这些请求可以通过逻辑控制器组合,请求也可以直接放在线程组下面。

控制器主要有“if控制器”,“循环控制器”等。

右键单击线程组,选择“添加”-“逻辑控制器”,可以选择各种控制器,如果是循环控制器,则该控制器下面的请求可以循环执行。

3、http请求

单击线程组或者某一个控制器,选择“添加”-“Sampler”-“HTTP请求”,设置http请求的各项参数。对于post请求,或者url带有参数的get请求,

其参数可以在 “同请求一起发送参数:”栏添加。

比如 http://www.xxxx.com这个请求,

其参数列表里面就要加上两个参数对:username (xxxxx),target(http://www.xxxxx.com)。

还有一个选项比较重要,“从HTML文件获取所有内含资源”,这个选项勾上后,就会加载html里面包含的所有静态资源。

4、定时器

定时器可以放在线程组和控制器下面,用来设置时间的延迟,如果放在一个控制器下面,则表示控制器下面的每一个请求都要延迟指定时间。

定时器包括固定定时器和其他类型的定时器,具体请参照jmeter帮助。

5、监听器

监听器主要用来监视jmeter各个请求的执行结果。可以放在线程组,控制器或者请求下面,放到不同地方,该监听器的作用范围也随之变化。

常用的有聚合报告,aggregate graph,用表格察看结果和察看结果树。

聚合报告显示每个请求在各个循环中的总体统计信息,比如平均响应时间,平均吞吐量等;aggregate graph跟聚合报告差不多,增加了图形显示;

用表格察看结果记录了各个请求各次执行的信息,比较全面;而察看结果树更加仔细,类似于截包工具的显示,把请求的url,内容和response信息都显示出来。

1.  JMeter的工作原理是什么?

向服务器提交请求;从服务器取回请求返回的结果。

2.  JMeter的作用?

JMeter可以用于测试静态或者动态资源的性能(文件、Servlets、Perl脚本、java对象、数据库和查询、ftp服务器或者其他的资源)。

JMeter用于模拟在服务器、网络或者其他对象上附加高负载以测试他们提供服务的受压能力,或者分析他们提供的服务在不同负载条件下的总性能情况。

你可以用JMeter提供的图形化界面分析性能指标或者在高负载情况下测试服务器/脚本/对象的行为。

3.

怎样能看到jmeter提供的脚本范例?

在\JMeter\jakarta-jmeter-2.0.3\xdocs\demos目录下。

4.怎样设置并发用户数?

选中可视化界面中左边树的Test Plan节点,单击右键,选择Add-> Thread Group,其中Number of Threads参数用来设置发送请求的用户数目。

5. JMeter的运行指示?

Jmeter在运行时,右上角有个单选框大小的小框框,运行是该框框为绿色,运行完毕后,该框框为白色。

6.  User Parameters的作用是什么?

提高脚本可用性

7. 在result里会出现彩色字体的http response code,说明什么呢?

Http response code是http返回值,彩色字体较引人注目,可以使用户迅速关注。像绿色的302就说明在这一步骤中,返回值取自本机的catch,而不是server。

8.怎样计算Ramp-up period时间?

Ramp-up period是指每个请求发生的总时间间隔,单位是秒。如果Number of Threads设置为5,而Ramp-up period是10,那么每个请求之间的间隔就是10/5,也就是2秒。

Ramp-up period设置为0,就是同时并发请求。

9. Get和Post的区别?

他们是http协议的2种不同实现方式。Get是指server从Request URL取得所需参数。从result中的request中可以看到,get可以看到参数,但是post是主动向server发送参数,

所以一般看不到这些参数的。

10. 哪些原因可能导致error的产生?

a.   Http错误,包括不响应,结果找不到,数据错误等等;

b.   JMeter本身原因产生的错误。

11. 为什么Aggregate Report结果中的Total值不是真正的总和?

JMeter给结果中total的定义是并不完全指总和,为了方便使用,它的值表现了所在列的代表值,比如min值,它的total就是所在列的最小值。下图就是total在各列所表示的意思。

12.  JMeter的Thread Number是提供多个不同用户并发的功能么?

不是,Thread Number仅仅是指并发数,如果需要实现多个不同用户并发,我们应该采用其它方法,比如通过在jmeter外建立csv文件的方法来实现。

13. 同时并发请求时,若需要模拟不同的用户同时向不同的server并发请求,怎样实现呢?

方法很灵活,我们可以将不同的server在thread里面预先写好。或者预先将固定的变量值写入csv文件,这样还可以方便修改。然后将文件添加到User Parameters。

14. User Parameter的DUMMY是什么意思?

当其具体内容是${__CSVRead(${__property(user.dir)}${FILENAME},next())}时用来模拟读文件的下一行。

15. 当测试对象在多server间跳转时,应该怎样处理?

程序运行时,有些http和隐函数会携带另外的server IP,我们可以从他们的返回值中获取。

16.  为何测试对象是http和https混杂出现?

Https是加密协议,为了安全,一般不推荐使用http,但是有些地方,使用https过于复杂或者较难实现,会采用http协议。

17. Http和https的默认端口是什么?

Apache server (Http)的默认端口是80;

SSL (Https)的默认端口是443。

18. 为何在run时,有些页面失败,但是最后不影响结果?

原因较多,值得提及的一种是因为主流页面与它不存在依赖关系,所以即使这样的页面出错,也不会影响运行得到正常结果,但是这样会影响到测试的结果以及分析结果。

19. 为什么脚本刚开始运行就有错误,其后来的脚本还可运行?

在Thread Group中有相关设置,如果选择了continue,即使前面的脚本出现错误,整个thread仍会运行直到结束。选择Stop Thread会结束当前thread;

选择Stop Test则会结束全部的thread。推荐选项是Stop Thread。

20.     在Regular Expression Extractor会看到Template的值是$1$,这个值是指

$1$是指取第一个()里面的值。如果Regular Expression的数值有多个,用这种方法可以避免不必要的麻烦。

21.    Regular Expression中的(.*)是什么意思?

那是一个正则表达式(regular expression)。’.’等同于sql语言中的’?’,表示可有可无。’*’表示0个或多个。’()’表示需要取值。(.*)表达任意长度的字符串。

22.   在读取Regular Expression时要注意什么?

一定要保证所取数值的绝对唯一性。

23.

怎样才能判断什么样的情况需要添加Regular Expression Extractor?

检查Http Request中的Send Parameters,如果有某个参数是其前一个page中所没有给出的,就要到原文件中查找,

并添加Regular Expression Extractor到其前一page的http request中。

24. 在自动获取的脚本中有时会出现空的http request,是什么意思呢?

是因为在获取脚本时有些错误,是脚本工具原因。在run时这种错误不参与运行的。

25.在运行结果中为何有rate为N/A的情况出现?

可能因为JMeter自身问题造成,再次运行可以得到正确结果。

26. 常用http错误代码有哪些?

400无法解析此请求。

403禁止访问:访问被拒绝。

404找不到文件或目录。

405用于访问该页的HTTP动作未被许可。

410文件已删除。

500服务器内部错误。

501标题值指定的配置没有执行。

502 Web服务器作为网关或代理服务器时收到无效的响应。

27. Http request中的Send Parameters是指什么?

是指code中写定的值和自定义变量中得到的值,就是在运行页面时需要的参数。

28.Parameters在页面中是不断传递的么?

是的。参数再产生后会在页面中一直传递到所需页面。所以我们可以在动态参数产生时捕获它,也可以在所需页面的上一页面捕获。(但是这样可能有错误,最好在产生页面获取)

29. 在使用JMeter测试时,是完全模拟用户操作么?造成的结果也和用户操作完全相同么?

是的。JMeter完全模拟用户操作,所以操作记录会全部写入DB.在运行失败时,可能会产生错误数据,这就取决于脚本检查是否严谨,否则错误数据也会进入DB,给程序运行带来很多麻烦。

时间: 2024-11-03 21:25:39

jmeter笔记1的相关文章

jmeter笔记5

性能测试是任何分布式或Web应用程序测试计划的重要组成部分.在计划和开发周期中进行性能评价,可以保证交付给客户的应用程序满足客户对于高负载.可用性和可伸缩性的要求. 性能测试是任何分布式或Web应用程序测试计划的重要组成部分.在计划和开发周期中进行性能评价,可以保证交付给客户的应用程序满足客户对于高负载.可用性和可伸缩性的要求.提前确定软件的负载限制可以为适当地进行系统配置提供帮助,从而避免出现意料之外的故障.系统性能分析中要处理的几个问题是:系统或服务器能否处理数百个或数千个客户端的同时请求,

jmeter笔记2

使用jmeter它来完成最常用的三种类型服务器,即 Web 服务器.数据库服务器和消息中间件,压力测试的方法.步骤以及注意事项. 讲到测试,人们脑海中首先浮现的就是针对软件正确性的测试,即常说的功能测试.但是软件仅仅只是功能正确是不够的.在实际开发中,还有其它的非功能因素也起着决定性的因素,例如软件的响应速度.影响软件响应速度的因素有很多,有些是因为算法不够高效:还有些可能受用户并发数的影响. 在众多类型的软件测试中,压力测试正是以软件响应速度为测试目标,尤其是针对在较短时间内大量并发用户的访问

Jmeter笔记:响应断言详解

平时我们使用jmeter进行性能测试时,经常会用到断言.jmeter提供了很多种断言,本来想全都写一下,但发现每一个断言里面的东西都很多,所以就先写一下我们经常使用的响应断言. 响应断言 :对服务器的响应进行断言校验 (1)应用范围: main sample and sub sample, main sample only , sub-sample only , jmeter variable 关于应用范围,我们大多数勾选“main sample only” 就足够了,因为我们一个请求,实质上只

Jmeter笔记

熟悉几个专有名词: 1.测试计划是顺序执行的,一个性能测试必须有的三部分:测试计划.线程组.sampler(采样器)--核心 2.控制器(用来定义请求执行的):loop if else 3.timer:请求与请求之间的延时. 4.断言:可以直接加载采样器之后,用于判断采样器的输出结果是否符合预期. 5.监听器:统计结果,输出测试报告用--聚合报告 =========================================================== jmeter目录结构说明: 测

Jmeter笔记2:参数化

案例:邮箱登录操作,参数化登录的用户名 方法一.依赖Jmeter自带的函数助手 选项-->函数助手对话框,即可打开函数助手弹窗 (1)比如使用函数_Random 输入最小值.最大值,点击下方的[生成]按钮,即会生成:${__Random(1,5,)} 假如邮箱是163的,则用户名参数的值直接填入:${__Random(1,5,)}@163.com,我测试的邮箱是内网测试用的域名是180chen.cn,则填写${__Random(1,5,)}@180chen.cn (2)比如使用函数__CSVRe

【转】Jmeter笔记:响应断言详解

平时我们使用jmeter进行性能测试时,经常会用到断言.jmeter提供了很多种断言,本来想全都写一下,但发现每一个断言里面的东西都很多,所以就先写一下我们经常使用的响应断言. 第一次在cnblog上写东西,不会排版,希望达人指点. 响应断言 :对服务器的响应进行断言校验 (1)应用范围: main sample and sub sample, main sample only , sub-sample only , jmeter variable 关于应用范围,我们大多数勾选“main sam

jmeter笔记4

软件测试中使用JMeter测试Web应用 JMeter作用领域 JMeter可以用于测试静态或者动态资源的性能(文件.Servlets.Perl脚本.java对象.数据库和查询.ftp服务器或者其他的资源).JMeter用于模拟在服务器.网络或者其他对象上附加高负载以测试他们提供服务的受压能力,或者分析他们提供的服务在不同负载条件下的总性能情况.你可以用JMeter提供的图形化界面分析性能指标或者在高负载情况下测试服务器/脚本/对象的行为. 使用JMeter测试Web应用 接下来的章节里,作者将

Jmeter 笔记

Apache JMeter是Apache组织开发的基于Java的压力测试工具.用于对软件做压力测试,它最初被设计用于Web应用测试但后来扩展到其他测试领域. 它可以用于测试静态和动态资源例如静态文件.Java 小服务程序.CGI 脚本.Java 对象.数据库, FTP 服务器, 等等.JMeter 可以用于对服务器.网络或对象模拟巨大的负载,来自不同压力类别下测试它们的强度和分析整体性能.另外,JMeter能够对应用程序做功能/回归测试,通过创建带有断言的脚本来验证你的程序返回了你期望的结果.为

JMeter笔记4:测试结果-聚合报告的字段说明

1.Lable :定义 HTTP 请求名称2.Samples :表示这次测试中一共发出了多少个请求3.Average :平均响应时长---默认情况下是单个Request的平均响应时长,当使用Transcation Controller时,也可以以Transcation为单位显示平均响应时长4.Median :中位数,也就是50%用户的响应时长5.90%Line :第90百分位用户的响应时长(响应时长按从小到大排序,第90%个用户的响应时长)6.Min:访问页面的最小响应时长7.Max:访问页面的