zoukankan      html  css  js  c++  java
  • 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提供的脚本范例?
    在JMeterjakarta-jmeter-2.0.3xdocsdemos目录下。
     
    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,给程序运行带来很多麻烦。
     
  • 相关阅读:
    分布式日志收集系统: Facebook Scribe之日志收集方案
    20111030 19:37 杨辉三角形 (java)
    pku acm 1833 排列
    俞敏洪郑大演讲经典语句
    自己在inode客户端的大量问题(不断更新中)(20120223 21:24 )
    智力测验:硬币问题
    windows up可以更新但是无法上网的一天挣扎
    hdu1754 I Hate It
    acm算法资源网站
    pku3041 Asteroids
  • 原文地址:https://www.cnblogs.com/kuihua/p/5452341.html
Copyright © 2011-2022 走看看