zoukankan      html  css  js  c++  java
  • Jmeter学习笔记1-实践介绍

    用此案例串起来jmeter的全部流程操作,我们无需关注深究具体为什么这样做,顺下来流程即可。

    1.被测试的项目描述:

    (1)被测试网站:xqtesting.blog.51cto.com

    (2)指标:响应时间以及错误率

    (3)场景如下图中所示配置:

    2.测试步骤

    (1)测试计划

    (2)线程组

    (3)http请求

    (4)监听器

    (5)查看报告

    3.对http请求界面相关录入的说明,界面如下:

    (1)名称:原则上可以随意命名,但是最好采用一个有意义的名字

    (2)注释:用户记录用户可读的注释信息,但在测试中无任何作用。

    (3)服务器名称或ip:http请求发送的目标服务器地址或ip,例如本案例中服务器名称就是:

           xqtesting.blog.51cto.com

    (4)端口号:目标服务器的端口号,默认为80.

    (5)timeouts超时定义可以不用填写。

    (6)协议:向目标服务器发送http请求时的协议,可以是http或是https,默认为http.

    (7)方法:发送http请求的方法,有post或是get等。

    (8)content encoding:内容的编码方式

    (9)路径:目标URL路径(不包含服务器地址和端口)

    (10)自动重定向:如果选中该选项,当发送Http请求后得到的响应是302/301时,Jmeter自动重定向到新的界面

    (11)Use keep Alive-持久的长链接:如果选中该选项,jmeter和目标服务器之间使用Keep-aLive方式进行http通信,默认选中。

    (12)use multipart/from-data for HTTP POST:当发送HTTP POST请求时,使用use multipart/from-data方法发送,默认不选中。

    (13)同请求一起发送参数:在请求中发送URL参数,对于带参数的URL,jmeter提供了一个简单的参数化方法,用户可以将URL中所有参数设置在本表中,

    表中的每一行是一个参数值对,一一对应。

    (14)同请求一起发送文件:在请求中发送文件,通常,HTTP文件上传行为可以通过这种方式进行模拟。

     (15)从HTML文件获取所有有内含的资源:当该选项被选中时,jmeter在发出HTTP请求并获得相应的HTML文件内容后,还对该HTML进行Parse并获取HTML中包含的所有资源(图片、flash等),默认不选中。

    如果用户只希望获取页面中的特定资源,可以在下方的Embedded URLs must match文件框中填入需要下载的特定资源表达式,这样,只有能匹配指定正则表达式的URL指向资源会被下载。

    (16)用作监视器:此取样器被当成监视器,在Monitor Results Listener中可以直接看到基于该取样器的图形化统计信息,默认不选中。

    (17)Save reponse as MD5 hash?:选中该项,在执行时仅记录服务端响应数据的MD5值,而不记录完整的响应数据,在需要进行数据量非常大的测试时,建议选中该项以减少取样器记录响应数据的开销。

    以上说的各项内容一般情况下都选择默认项即可,无需配置。
    按照案例中设置值完毕的样例如下:

    4.场景-线程组设置

    (1)线程数:虚拟用户数

    (2)Ramp-Up period:即为场景加载的策略,设置的虚拟用户数需要多长时间全部启动。如果线程数为20,时间为10,也就是说每秒启动2个线程。

    (3)循环次数:每个线程发送请求的次数。如果线程数为20,循环次数为10,那么每个线程发送10次请求,总请求数为20*10=200。

    如果勾选了永远,那么所有线程会一直请求直到停止。

    不勾选永远默认。总的请求运行时间为10*10=100秒。

    (4)调度器:可以更灵活的设置运行时间等。

    (5)总结起来:

    线程数/Ramp-Up period---------即为线程增加的策略,每秒增加多少个线程

    线程数*循环次数-----------------即为请求的所有次数

    Ramp-Up period*循环次数-------即为运行的时间

    5.监听器-聚合报告

    注意:jmeter中的监控中显示的时间单位都为毫秒。

     说明如下:

    label:定义的http请求名称

    Samples:表示这次测试中一共发出的请求总数。

    Average:平均响应时长-默认情况下是单个Request的平均响应时长,当使用了Transaction Controller时,也可以以Transaction为单位显示平均响应时长

    Median:中位数,也就是50%用户的响应时长。

    90%line:90%用户的响应时长

    Min:访问页面的最小响应时长

    Max:访问页面的最大响应时长

    Error%:错误请求的数量/请求的总数

    Throughput:默认情况下表示每秒完成的请求数(Request per second),当使用了Transaction Controller时,也可以表示类似Loadrunner的transaction per second数。

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

    所有数据可以写入到一个文件中,但是文件格式需要为.jtl

    6.运行脚本

    执行完一次压测后,jmeter的结果会累加,所以要执行下一次压测时,需要及时清除上面的结果即点击下图中的清除全部按钮:

    7.总结

    我们需要掌握执行的步骤:

    测试计划->线程组:设置场景->添加http请求->添加监听器:即结果树和聚合报告

  • 相关阅读:
    11g 配置 dgmgrl 以及报错 DataGuard ORA-00313,
    java三种匿名的方式开启线程
    java 四种方式实现字符流文件的拷贝对比
    java中过滤查询文件
    通过Java实现斗地主
    java中Map的entrySet 和keySet的使用
    python3列表推导式和生成器。
    python的特殊方法总结
    python3 定义向量运算
    python3模拟扑克牌
  • 原文地址:https://www.cnblogs.com/haibaowang/p/6884816.html
Copyright © 2011-2022 走看看