zoukankan      html  css  js  c++  java
  • 【转】Jmeter应用评估

    Jmeter应用评估

    字体:        | 上一篇 下一篇 | 打印  | 我要投稿  | 推荐标签: 性能测试工具 Jmeter

      综述:

      在客户端程序上,与LR相比,jmeter只有一个主程序,脚本设计、场景设计、运行监视、报告结果均在一起完成,没有独立的调试器,所以脚本实际上跟场景是一体的;

      在概念上,jmeter的测试计划可以对应LR的测试场景,而线程组可以对LR的测试脚本,与LR不同的是,jmeter的线程组既可以设置各自的并发用户数,也可以设置各自的运行时间;jmeter使用各种取样器作为请求的发生器,比如我们会经常用到的“HTTP请求”取样器,可以对应到LR的请求函数“web_url”(get)“web_submit_data”(post);使用逻辑控制器来实现“if”“swith”“for each”“while”来实现逻辑语法;定时器可以实现think time;报表中的Throughput对应LR中的TPS,KB/sec对应LR中的Throughput,这一点可能容易混淆。

      在结构上,jmeter使用各种元件组成脚本,代码为树形结构(.jmx脚本为xml格式)。

      在功能上,jmeter没有独立的调试器,必须运行来进行脚本的调试;没有目标场景,但从用户手册的说明上来看,应该可以通过元件组合实现目标场景;只有针对响应时间的统计图形展现,没有针对事务数的统计图形展现;资源监视模块只针对tomcat(5以上),解析tomcat的status返回的xml来实现,没有Linux资源监控。

      脚本功能:

      利用代理服务器截取协议包方式,脚本形式为xml,解析执行,没有单独的调试器。代理服务器可以生成“HTTP请求”取样器脚本以及定时器。

      Jmeter脚本由各种jmeter元件组成。这些元件有:取样器、配置元件、定时器、逻辑控制器、前置处理器、后置处理器、断言、报告。

      取样器:生成压力的元件,如产生http请求、ftp请求等

      配置元件:与脚本中的配置有关,如用户变量、cookies设置、http头设置等

      定时器:产生延时(think time)

      逻辑控制器:对代码做逻辑控制,如if条件判断、for循环等

      前置处理器:取样器操作前的处理,如用户参数、URL rewrite等

      后置处理器:取样器操作后的处理,如提取响应信息(关联数据)等

      断言:即检查点,支持正则

      报告:结果展现,如响应数据、服务器监控数据等

      参数化文件:两种读取方式——CSV Data Set Config元件和函数:

      CSV Data Set Config元件提供比较丰富的参数设置:编码方式、分隔符、循环使用、共享模式;这里有一个注意点:“Allow quote data”选项选为“true”的时候对全角字符的处理出现乱码。利用设置共享模式可以实现在LR中的“Sequential”和“Unique”,对应选项为:“Sequential”用“Current thread”;“Unique”用“Current thread group”(当前的线程组内)或“All treads”(所有的线程组中)。

      “StringFromFile”和“CSVRead”函数也可以实现读取参数化文件,“StringFromFile”的方式类似于“Unique”,而“CSVRead”很特别,是每个线程只读取一行作为参数,无论循环多少次,各个线程依次读取。

      其它参数化,函数实现:

      1. 使用线程名作为参数:“threadNum”函数,返回格式为“线程组名称+空格+线程组编号+横线+线程编号”;

      2. 使用机器名作为参数:“machineName”函数;

      3. 使用时间作为参数:“time”函数;

      4.使用随机数作为参数:“Random”函数

      检查点:jmeter提供的断言种类很丰富,支持正则表达式的多种匹配规则。

      压力产生的元件是取样器,其中最常用的是“HTTP请求”。利用逻辑控制器元件可以实现条件判断、循环等算法。

      另外jmeter提供了后置处理器元件建立关联,常用的是“正则表达式提取器”元件,提取响应返回的数据产生关联数据,进行后续处理或用于后面的请求。

      场景设置:

      没有目标场景

      线程组可理解为LR Controller中的单个脚本,多个线程组就是多个脚本,可以通过禁用/启用操作来控制执行的线程组。

      可以设置逐步增加压力,也可以设置一次性加压。

      设置集合点:通过“Synchronizing Timer”这个定时器,可以设置多少个并发用户集合到一起。

      监控资源:使用“监视器结果”来监控,但目前只支持tomcat(5以上);原理:该功能是通过解析tomcat的管理status返回的xml实现的;监控得到的结果是负载、内存、线程。

      可以通过逻辑控制器,以及不同的配置原件来模拟不同的业务场景

  • 相关阅读:
    STM32F103ZET6 PWM输出
    STM32F103ZET6串口通信
    STM32F103ZET6系统定时器SysTick
    STM32F103ZET6的基本定时器
    npm 安装vue cli脚手架报错 npm err code EEXIST 或者 npm err cb<> never called 解决方案
    Java调用第三方http接口的方式
    机器学习算法原理解析
    Spark MLlib 机器学习
    Spark SQL基本概念与基本用法
    HBase基本概念与基本使用
  • 原文地址:https://www.cnblogs.com/blongfree/p/4980988.html
Copyright © 2011-2022 走看看