51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 2111|回复: 1
打印 上一主题 下一主题

使用JMeter做性能测试的心得

[复制链接]
  • TA的每日心情
    无聊
    前天 09:06
  • 签到天数: 530 天

    连续签到: 2 天

    [LV.9]测试副司令

    跳转到指定楼层
    1#
    发表于 2018-11-27 17:22:41 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    本帖最后由 测试积点老人 于 2018-11-27 17:38 编辑

    一、基本概念
    1.测试计划是使用 JMeter 进行测试的起点,它是其它 JMeter 测试元件的容器。
    2.线程组:代表一定数量的并发用户,它可以用来模拟并发用户发送请求。实际的请求内容在Sampler中定义,它被线程组包含。可以在“测试计 划->添加->线程组”来建立它,然后在线程组面板里有几个输入栏:线程数、Ramp-Up Period(in seconds)、循环次数,其中Ramp-Up Period(in seconds)表示在这时间内创建完所有的线程。如有8个线程,Ramp-Up = 200秒,那么线程的启动时间间隔为200/8=25秒,这样的好处是:一开始不会对服务器有太大的负载。线程组是为模拟并发负载而设计。
    3、取样器(Sampler):模拟各种请求。所有实际的测试任务都由取样器承担,存在很多种请求。如:HTTP 、ftp请求等等。
    4、监听器:负责收集测试结果,同时也被告知了结果显示的方式。功能是对取样器的请求结果显示、统计一些数据(吞吐量、KB/S……)等。
    6、断言:用于来判断请求响应的结果是否如用户所期望,是否正确。它可以用来隔离问题域,即在确保功能正确的前提下执行压力测试。这个限制对于有效的测试是非常有用的。
    7、定时器:负责定义请求(线程)之间的延迟间隔,模拟对服务器的连续请求。
    5、逻辑控制器:允许自定义JMeter发送请求的行为逻辑,它与Sampler结合使用可以模拟复杂的请求序列。
    8. 配置元件维护Sampler需要的配置信息,并根据实际的需要会修改请求的内容。
    9. 前置处理器和后置处理器负责在生成请求之前和之后完成工作。前置处理器常常用来修改请求的设置,后置处理器则常常用来处理响应的数据。

    二、Jmeter报告
    1、Aggregate Report 解析
    Aggregate Report 是 JMeter 常用的一个 Listener,中文被翻译为“聚合报告”。今天再次有同行问到这个报告中的各项数据表示什么意思,顺便在这里公布一下,以备大家查阅。
    如果大家都是做Web应用的性能测试,例如只有一个登录的请求,那么在Aggregate Report中,会显示一行数据,共有10个字段,含义分别如下。
    Label:每个 JMeter 的 element(例如 HTTP Request)都有一个 Name 属性,这里显示的就是 Name 属性的值
    #Samples:表示你这次测试中一共发出了多少个请求,如果模拟10个用户,每个用户迭代10次,那么这里显示100
    Average:平均响应时间——默认情况下是单个 Request 的平均响应时间,当使用了 Transaction Controller 时,也可以以Transaction 为单位显示平均响应时间
    Median:中位数,也就是 50% 用户的响应时间
    90% Line:90% 用户的响应时间
    Note:关于 50% 和 90% 并发用户数的含义,请参考下文
    http://www.cnblogs.com/jackei/archive/2006/11/11/557972.html
    Min:最小响应时间
    Max:最大响应时间
    Error%:本次测试中出现错误的请求的数量/请求的总数
    Throughput:吞吐量——默认情况下表示每秒完成的请求数(Request per Second),当使用了 Transaction Controller 时,也可以表示类似 LoadRunner 的 Transaction per Second 数
    KB/Sec:每秒从服务器端接收到的数据量,相当于LoadRunner中的Throughput/Sec

    基本知识:
    1、吞吐量:是指在没有帧丢失的情况下,设备能够接受的最大速率。
    2、存储的最小单位是字节Byte,对于存储单位,有以下几个单位,GB、MB和KB,那么这三者之间的换算关系是:1GB=1024MB,1MB=1024KB,1KB=1024Bytes。
    Bit :“位”,称为bit,也就是比特,有的时候也称为位。一个字节为8位二进制表示。
    Byte:“字节”,一个字节就是8比特。
    3、Mbps (million bits per second 兆位/秒) 代表每秒传输1,000,000比特。该缩写用来描述数据传输速度。例如:4Mbps=每秒钟传输4M比特。
    数据传输速率的单位,字母b(bit)是比特和字母 B (Byte)是字节。
    4、吞吐量与带宽的区分:吞吐量和带宽是很容易搞混的一个词,两者的单位都是Mbps.先让我们来看两者对应的英语,吞吐 量:throughput ; 带宽: Max net bitrate 。当我们讨论通信链路的带宽时,一般是指链路上每秒所能传送的比特数。我们可以说以太网的带宽是10Mbps。但是,我们需要区分链路上的可用带宽(带 宽)与实际链路中每秒所能传送的比特数(吞吐量)。我们倾向于用“吞吐量”一次来表示一个系统的测试性能。这样,因为实现受各种低效率因素的影响,所以由 一段带宽为10Mbps的链路连接的一对节点可能只达到2Mbps的吞吐量。这样就意味着,一个主机上的应用能够以2Mbps的速度向另外的一个主机发送 数据。
    5、方差和标准差都是用来描述一组数据的波动性的(集中还是分散),标准差的平方就是方差。方差越大,数据的波动越大。

    三.利用BadBoy生成测试计划(测试脚本)
    badBoy可以非常容易的生成web的测试脚本。类似与LoadRunner的使用,输入站点的URL,点击Record开始录制。File –> Export to Jmeter ,导出为Jmeter认识的测试脚本。

    四.一个简单的测试示例思路(目前自己思路,不断改进)
    a.需要的“测试脚本”,对应web的应用使用badboy生成测试脚本。直接导入Jmeter,进行配置

    b.如图
    TestPlan :是整个Jmeter测试执行的容器。
    ThreadGroup :模拟请求,定义线程数、Ramp-Up Period、循环次数。
    Step1 :循环控制器 ,控制Sample的执行次数。
    Sample取样器 :决定进行那种类型的测试,如http、ftp等。
    监听器 :图形结果、聚合报告。
    定时器 :Random类型,定义线程请求的延迟。
    c.聚合报告的解释
    Label :各个模拟测试的名称
    #Samples :各个测试的样本总数
    Average :每个请求的平均响应时间
    Median :中值,即50%请求的平均响应时间
    90%Line :90%请求的响应时间
    Min :最小响应时间 ,Max :最大的响应时间
    Error% :错误响应的概率。即无法响应的概率。
    ThroughPut :吞吐量 -- 默认情况下表示每秒完成的请求数(Request per Second)。
    KB/Sec :每秒从服务器端接收到的数据量。

    五.Jmeter常见问题
      说明:这些问答是从网上转载的,自己修改了其中的一些内容,如果大家兴趣,可以将大家在使用Jmeter的时候碰到的问题写下来,我们一起补充到这个问答里面,共同努力完善jmeter的资料。
    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。



    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏1
    回复

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-11-23 03:00 , Processed in 0.072795 second(s), 22 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表