1. 场景设计

场景设计的原则:忠于用户实际操作,组合用户的各种操作到场景中来。

JMeter场景主要通过线程组设置来完成的,对于复杂场景还需要与逻辑控制器配合完成。

2.场景设置

JMeter线程组实际上是建立一个线程池,JMeter根据用户的设置进行线程池的初始化,在运行时做各种异常的处理。

参数说明:

√ 名称:可以随意设置,最好有业务意义

√ 注释:可以随意设置,可以为空

√ 在取样器错误后要执行的动作:也就是其中的某一个请求出错后的异常处理方式。

  (1)继续:请求(Sampler元件模拟的用户请求)出错后继续运行;

  (2)Start Next Thread Loop:如果出错,则同一脚本中的余下请求将不再执行,直接重新开始执行;

  (3)停止线程:如果遇到请求(Sampler元件模拟的请求)失败,则停止当前线程,不再执行;

  (4)停止测试:如果某一线程的某一请求失败了,则停止所有线程,也就是 听下整个测试;

  (5)Stop Test Now:如果有现成的请求失败了,马上停止整个测试场景。

√ 线程属性:

  (1)线程数:运行的线程数设置,一个线程对应一个模拟用户

  (2)Ramp-Up Period(in second):线程启动开始运行的时间间隔,单位是秒;

  (3)循环次数:请求的重复次数,选择后面的forever,那么请求将一直继续除非停止或崩溃;如果不选择forever而在输入框中输入数字,那么请求将重复指定的次数;

  (4)Delay Thread creation util needed:勾选,线程在Ramp-up Period的间隔时间启动并运行;

  Java线程相关知识:

  (1)NEW:创建未启动,已经实例化,只是没有开始运行线程的Run方法;

  (2)RUNNABLE:就绪状态,线程对象创建后,其他现成调用了该对象的start()方法,该状态的线程位于可运行线程池中,已经准备好了只等获取CPU的使用权,然后开始运行;

  (3)RUNNING:运行状态,就绪状态的线程获取了CPU使用权执行程序代码;

  (4)BLOCKED:阻塞状态,线程因为某种原因放弃CPU使用权,暂时停止运行(典型的如IO等待导致的线程处于BLOCKED状态);直到线程进入就绪状态,才有机会转到运行状态;

  (5)DEAD:死亡状态,执行完毕或者异常退出,线程生命周期结束。

√ 调度器配置:设置何时开始运行

  (1)启动时间:测试计划什么时候启动,时间格式“2018/03/22 09:10:10”

  (2)结束时间:测试计划什么时候结束,时间格式“2018/03/22 12:13:14”

  (3)持续时间:测试计划持续多久时间,如果启动时间+持续时间大于结束的时间,那么此设置覆盖结束时间

  (4)启动延迟:点击执行按钮后(此时间未T),仅初始化场景,不运行线程,等待延迟到时候开始运行线程。

3. 场景运行

JMeter的场景运行方式分为两种,一种是GUI(视窗运行,即我们可以看到的运行界面)方式;一种是非GUI方式运行(命令窗口)。

JMeter的场景运行基于运行架构分为两种,一种是本地化运行,即单机运行;另一种是远程运行。

JMeter非GUI运行的命令:

(1)java -jar %JMETER_HOME%\bin\ApacheJMeter.jar -n -t %JMETER_HOME%\script\Jforum4-1-01.jmx -r -l result.jtl

(2)%JMETER_HOME%\bin\jmeter -n -t %JMETER_HOME%\script\Jforum4-4-01.jxm -l%JMETER_HOME%\result\results.jsl

4. 性能参数配置

5. 测试监听

性能测试监控的主要任务是获取运行状态收集测试结果,测试结果有事务响应时间、吞吐量及服务器硬件性能(CPU、内存、磁盘等)、JVM使用情况、数据库性能状态等。

  5.1 JMeter监听器

  常使用的监听器主要是Summary Report或者Aggregate Graph。

  Summary Report以表格的形式显示取样器结果,如果不同取样器(不同请求)拥有相同的名字,那么在Summary Report中会统计到同一行,所以在给取样器取别名时最好不要为空,建议按业务功能来取名。

  

  结果说明如下:

  √ Label:取样器别名(或者说是事务名),比如我们提交一笔订单,那么取样器我们可以命名为“订单提交

  √ #Samples:取样器运行次数(提交了多少笔业务)

  √ Average:请求事务的平均响应时间

  √ Min:请求的最小响应时间

  √ Max:请求的最大响应时间

  √ Std. Dev:响应时间的标准偏差

  √ Error%:事务错误率

  √ Throughput:吞吐率,常说的TPS

  √ Recevied/Sent KB/sec:每秒数据流量包,单位KB

  √ Avg.Bytes:平均数据流量,单位Byte

  在Summary Report界面可以设置结果属性(包含哪些结果字段),点击到下图所示界面。

  

  Aggregate Graph以表格形式显示取样器结果,如下图所示。

  

  结果说明:

  √ Lable:请求别名

  √ Samples:执行了多少次取样

  √ Median:响应时间中间值

  √ 90% Line:90%事务响应时间范围

  √ Min:最小响应时间

  √ Max:最大响应时间

  √ Error%:出错率

  √ Throghput:吞吐量,可以理解为TPS

  √ Received/Sent KB/sec:数据传输量,单位KB

JMeter学习笔记(六)-负载与监听的更多相关文章

  1. jmeter学习记录--03--jmeter负载与监听

    jmeter场景主要通过线程组设置完成,有些复杂场景需要与逻辑控制器配合. 一.测试计划设计与执行 场景设计 jmete线程组实际是一个线程池,根据用户设置进行线程池的初始优化,在运行时做各种异常的处 ...

  2. jQuery-mobile 学习笔记之三(事件监听)

    续上 触摸事件 - 当用户触摸屏幕时触发(敲击和滑动) 滚动事件 - 当上下滚动时触发 方向事件 - 当设备垂直或水平旋转时触发 页面事件 - 当页面被显示.隐藏.创建.载入以及/或卸载时触发 一.初 ...

  3. Jmeter 04 JMeter 负载与监听

    1. 场景设计 2. 场景设置 3. JMeter性能参数配置 4. 测试监听

  4. # go微服务框架kratos学习笔记六(kratos 服务发现 discovery)

    目录 go微服务框架kratos学习笔记六(kratos 服务发现 discovery) http api register 服务注册 fetch 获取实例 fetchs 批量获取实例 polls 批 ...

  5. Java IO学习笔记六:NIO到多路复用

    作者:Grey 原文地址:Java IO学习笔记六:NIO到多路复用 虽然NIO性能上比BIO要好,参考:Java IO学习笔记五:BIO到NIO 但是NIO也有问题,NIO服务端的示例代码中往往会包 ...

  6. java之jvm学习笔记六-十二(实践写自己的安全管理器)(jar包的代码认证和签名) (实践对jar包的代码签名) (策略文件)(策略和保护域) (访问控制器) (访问控制器的栈校验机制) (jvm基本结构)

    java之jvm学习笔记六(实践写自己的安全管理器) 安全管理器SecurityManager里设计的内容实在是非常的庞大,它的核心方法就是checkPerssiom这个方法里又调用 AccessCo ...

  7. Learning ROS for Robotics Programming Second Edition学习笔记(六) indigo xtion pro live

    中文译著已经出版,详情请参考:http://blog.csdn.net/ZhangRelay/article/category/6506865 Learning ROS for Robotics Pr ...

  8. Typescript 学习笔记六:接口

    中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...

  9. python3.4学习笔记(六) 常用快捷键使用技巧,持续更新

    python3.4学习笔记(六) 常用快捷键使用技巧,持续更新 安装IDLE后鼠标右键点击*.py 文件,可以看到Edit with IDLE 选择这个可以直接打开编辑器.IDLE默认不能显示行号,使 ...

  10. Go语言学习笔记六: 循环语句

    Go语言学习笔记六: 循环语句 今天学了一个格式化代码的命令:gofmt -w chapter6.go for循环 for循环有3种形式: for init; condition; increment ...

随机推荐

  1. getaddrinfo()函数详解

    Socket的地址查询函数 http://blog.sina.com.cn/s/blog_988c054b010139e3.html http://www.cnblogs.com/cxz2009/ar ...

  2. socket编程—— 服务器遇到Broken Pipe崩溃

    我写了一个服务器程序, 在Linux下测试时, 总是莫名退出. 最后跟踪到是write调用导致退出. 用gdb执行程序, 退出时提示"Broken pipe". 最后问题确定为, ...

  3. 执行Socket socket = new Socket(ip, port);时抛出个异常:android.os.NetworkOnMainThreadException解决办法

    首先,确认你的android版本是4.0之后再用此方法解决,因为在4.0之后在主线程里面执行Http请求才会报这个错,也许是怕Http请求时间太长造成程序假死的情况吧.Android在4.0之前的版本 ...

  4. gradle 项目转成maven项目

    找到一个个子项目目录下的build.gradle文件,在文件开头添加以下内容: apply plugin: 'java' apply plugin: 'maven' compileJava.optio ...

  5. JPA中的一对多双向关联与级联操作

    学习Spring有两周时间了 , 个人觉得服务端主要实现的是数据关系的维护和数据结构的制定 , 以及由业务需求产生的CRUD , 只要保证对前端提供的接口稳定高效响应 , 具体的前端实现完全不关心. ...

  6. javaweb笔记全套

    Lesson 1 一.eclipse工具的使用 1. java代码的位置 1) 选择工作空间 workspace  选择一个文件夹存放程序(代码) 不要用中文和空格 2) 新建一个java 工程(Pr ...

  7. webpack插件html-webpack-plugin

    1.插件安装 npm install html-webpack-plugin --save-dev 2.插件使用 webpack.config.js配置文件为: var htmlWebpackPlug ...

  8. window下rabbitmq的配置问题

    最近项目想用个MQ来做业务分离,看了市面上众多产品,最后选了rabbitmq,理由很简单,对window的支持很到位(其实是公司的系列产品都是.net的). 安装方法什么的就不说了,直接到官网下载双击 ...

  9. SpringMVC之ModelAndView的用法(转)

    原文地址:https://blog.csdn.net/qq30211478/article/details/78016155 (一)使用ModelAndView类用来存储处理完后的结果数据,以及显示该 ...

  10. virtualenv沙箱

    准备用Django开发网站,豆瓣阅读中有<Django入门>,里面有人批注说用virtualenv+pip很好. 每次搞个什么都感觉举步维艰,因为之前太懒了,什么都懒得深入看一下.pip一 ...