一、JMeter官网

下载地址

http://jmeter.apache.org/download_jmeter.cgi

Jmeter wiki

https://wiki.apache.org/jmeter

二、概念

ElapsedTime

消耗时间,与ResponseTime/SampleTime一致,表示开始请求到响应接收完毕的时间;

Latency

延迟时间,仅包括开始请求到准备接收响应的时间;

90% Line

一种时间度量指标,表示90%的请求都在该响应时间内完成;

Throughput

吞吐量,指每秒处理的请求数;

公式:Throughput=(number of requests) / (total time)

吞吐量与响应时间/并发数的关系:

TPS=U_concurrent/(T_response+T_think)

其中T_think为用户思考时间

ThreadGroup

线程组,用于控制并发请求的组件;

设置参数

  1. 线程数量,控制并发数量
  2. rame-up周期,线程柔和增长周期,比如100个线程的增长周期是10s,那么1s增加10个线程
  3. 固定请求数量
  4. 循环执行设置,可指定开始和结束时间

SummaryReport

聚合报告,结果指标包括:

属性 描述
label 每个样本的名称
samples 测试请求总数量
average 平均响应时间
median 50%用户的响应时间
90%line 90%用户的响应时间
min 最小响应时间
max 最大响应时间
error% 错误发生率
recv KB/s 每秒接收的数据量
throughput 吞吐量(TPS)

三、启动停止

GUI启动

./jmeter.bat

命令行启动

jmeter -n -t xxx.jmx

停止测试

//平滑停止(gracefully stop, thread will stop at next opportunity)
./bin/shutdown.sh //立即停止(will kill thread directory)
./bin/stoptest.sh

四、使用变量

properties文件

Jmeter主要的配置文件

  1. jmeter.properties,定义jmeter运行的关键配置;
  2. system.properties,定义Java进程的系统变量,通过System.getProperties()可查询;
  3. user.properties,自定义配置,可覆盖jmeter.properties

命令行启动

-J 指定本地JMeter变量

-D 指定Java系统变量

-G 指定全局JMeter变量,在远程测试时会传输到测试节点

样例

PATH=$PATH:/opt/local/jre/bin
JVM_ARGS="-Xmx2048m -Xms512m -Xmn256m -XX:PermSize=128m -Xss256k"
jmeter -Jmongo.host=xxx -Jmongo.port=xxx -n -t test.jmx

JVM_ARGS 用于指定JVM大小,-n指定了no-gui模式启动

-Gglobal.properties可代替-Gvar=value的方式

引用方式

在测试计划中可通过函数对变量进行引用:

${__P(varName,defaultValue)}

五、远程测试

  1. 将jmeter部署到远程节点,启动server
PATH=$PATH:/opt/local/jre/bin
JVM_ARGS="-Xmx2048m -Xms512m -Xmn256m -XX:PermSize=128m -Xss256k" ./bin/jmeter-server &

端口设置

Jmeter-server采用RMI实现通讯,默认端口为1099

可编辑user.properties进行修改:

server_port=1999
  1. 本地配置远程节点

修改user.properties:

remote_hosts=xxx:1999
  1. 命令行执行

配置好远程节点之后,可直接通过GUI客户端执行测试,然而在自动化的场景下往往需要采用命令行方式执行:

//启动全部远程节点测试
jmeter -Gmongo.host=xxx -Gmongo.port=xxx -n -t test.jmx -r //指定部分远程节点测试
jmeter -Gmongo.host=xxx -Gmongo.port=xxx -n -t test.jmx -R192.168.0.100:1999,192.168.0.101:1999 //停止远程节点测试
jmeter -Gmongo.host=xxx -Gmongo.port=xxx -n -t test.jmx -R192.168.0.100:1999,192.168.0.101:1999 -Z

六、生成报告

jtl文件

Jmeter 执行测试后可生成jtl/csv/xml的结果文件,通过在结果监听器中添加输出路径可获得。

也可以通过命令行方式直接输出,如:

jmeter -n -t test.jmx-l result.jtl

html报告

Jmeter3.x支持直接生成HTML格式的报告,可参考详细说明

  1. 直接生成报告
jmeter -n -t test.jmx-l result.jtl -e -o /opt/local/jmeter/result/html

-e 表示生成html报告,-o指定目标路径(必须为空)

  1. 从jtl文件中转换
jmeter -g result.jtl -o /opt/local/jmeter/result/html

定制报告

修改user.properties:

//按sample名称过滤
jmeter.reportgenerator.sample_filter=find|update|delete|list|insert //APDEX模型-满足需求阈值(响应时间)
jmeter.reportgenerator.apdex_satisfied_threshold=300 //APDEX模型-可容忍阈值(响应时间)
jmeter.reportgenerator.apdex_tolerated_threshold=1200 //数据聚合频率,性能测试场景可适当减小,稳定性测试可加长,默认60s
jmeter.reportgenerator.overall_granularity=5000

关键报表

ResponseTimeOverTime

TransactionsPerSecond

ActiveThreadOverTime

ResponseTimePercentiesOverTime

七、性能监控

使用Perfmon插件,插件地址

  1. 部署ServerAgent

    将ServerAgent上传到目标服务器,执行startAgent.sh启动;

    默认情况下会启动4444,可修改启动端口:
./startAgent.sh --udp-port 7777 --tcp-port 7777
  1. 编辑Jmeter脚本文件,添加Perfmon监听器。

    可设置将监控数据输出到jtl文件用于后续分析

  2. 自动生成图片

    需借助JMeterPluginsCMD插件,下载地址

    命令行执行:

JMeterPluginsCMD.sh --generate-png cpu.png --input-jtl perfmon-cpu.jtl --plugin-type PerfMon --width 800 --height 600

八、常用插件

SteppingThreadGroup

插件地址

Jmeter自带的ThreadGroup只能均匀增加线程,无法模拟更真实的压力场景;

该插件支持更灵活的控制并发压力,如:

初始启动20线程,此后每10秒钟增加5个线程,到达100个线程之后持续运行100s...

CompositeGraph

插件地址

该插件将响应时间、吞吐量报表进行了组合,需依赖于其他几个插件。

在观察服务器极限性能时比较有用,可用于权衡指定请求频度下并发数大小。

通常情况下当并发数超过系统承受能力时,TPS出现明显下滑,响应时间持续上升。

九、参考资料

GitBook-Jmeter参考

https://aimer1124.gitbooks.io/jmeter-tutorial/

yukinami的博客

http://yukinami.github.io/2015/11/26/性能测试指南/

Jmeter逻辑控制器(总结的不错的一篇文章)

http://www.guru99.com/controllers-in-jmeter.html

Jmeter VS LoadRunner

http://www.cnblogs.com/shuiyelifang/p/5749523.html

TPS/响应时间/并发数的研究

http://blog.csdn.net/wind19/article/details/8600083

Jmeter3.1 使用技巧的更多相关文章

  1. 性能测试-Jmeter3.1 使用技巧

    一.JMeter官网 下载地址 http://jmeter.apache.org/download_jmeter.cgi Jmeter wiki https://wiki.apache.org/jme ...

  2. 探究javascript对象和数组的异同,及函数变量缓存技巧

    javascript中最经典也最受非议的一句话就是:javascript中一切皆是对象.这篇重点要提到的,就是任何jser都不陌生的Object和Array. 有段时间曾经很诧异,到底两种数据类型用来 ...

  3. 前端极易被误导的css选择器权重计算及css内联样式的妙用技巧

    记得大学时候,专业课的网页设计书籍里面讲过css选择器权重的计算:id是100,class是10,html标签是5等等,然后全部加起来的和进行比较... 我只想说:真是误人子弟,害人不浅! 最近,在前 ...

  4. 前端网络、JavaScript优化以及开发小技巧

    一.网络优化 YSlow有23条规则,中文可以参考这里.这几十条规则最主要是在做消除或减少不必要的网络延迟,将需要传输的数据压缩至最少. 1)合并压缩CSS.JavaScript.图片,静态资源CDN ...

  5. 工欲善其事,必先利其器 之 VS2013全攻略(安装,技巧,快捷键,插件)!

    如有需要WPF工具的朋友可以移步 工欲善其事,必先利其器 之 WPF篇: 随着开发轨迹来看高效WPF开发的工具和技巧 之前一篇<c++的性能, c#的产能?!鱼和熊掌可以兼得,.NET NATI ...

  6. 15个关于Chrome的开发必备小技巧[译]

    谷歌Chrome,是当前最流行且被众多web开发人员使用的浏览器.最快六周就更新发布一次以及伴随着它不断强大的开发组件,使得Chrome成为你必备的开发工具.例如,在线编辑CSS,console以及d ...

  7. Git小技巧 - 指令别名及使用Beyond Compare作为差异比较工具

    前言 本文主要写给使用命令行来操作Git的用户,用于提高Git使用的效率.至于使用命令还是GUI(Tortoise Git或VS的Git插件)就不在此讨论了,大家根据自己的的喜好选择就好.我个人是比较 ...

  8. 【工具使用】mac电脑使用技巧

    本文地址 分享提纲: 1.  mac命令行和finder的交互 2. 一些mac的插件 3. 一些开发的配置 1.mac命令行和findder交互           1)命令行中打开当前文件夹: o ...

  9. Function.prototype.toString 的使用技巧

    Function.prototype.toString这个原型方法可以帮助你获得函数的源代码, 比如: function hello ( msg ){ console.log("hello& ...

随机推荐

  1. 任务调度框架Quartz原理简介

    [TOC] 第一章 Quartz 1.1 Quartz概念 Quartz是OpenSymphony开源组织的一个Java开源项目, 在2009被Terracotta收购.Quartz官网 1.2 Qu ...

  2. npm 简单实用命令

    npm -v    查看版本号 npm get global             返回false表示默认本地安装 true全局安装 npm set global=true     设置默认为全局安 ...

  3. 下载的js文件本地编辑器打开中文乱码如何解决

    今天遇到的小问题,已解决,直接上图 下载直接打开是这样的 用记事本打开 另存为utf-8格式 正常了!

  4. MongoDB建立主从复制小案例(一主一从)

    花了两天学习了mongoDB, 今天接触到了mongo的主从配置, 把它记下来 1. 开启两个mongo服务器(用于一主一从, 没有加安全验证相关参数 : 可以使用mongd-help查看) mong ...

  5. April Fools Contest 2017 题解&源码(A,数学 B,数学 C,数学 D,字符串 E,数字逻辑 F,排序,卡时间,G,数学)

    A. Numbers Joke time limit per test:2 seconds memory limit per test:64 megabytes input:standard inpu ...

  6. Educational Codeforces Round 21 D.Array Division(二分)

    D. Array Division time limit per test:2 seconds memory limit per test:256 megabytes input:standard i ...

  7. 使用 SVG 和 JS 创建一个由星形变心形的动画

    序言:首先,这是一篇学习 SVG 及 JS 动画不可多得的优秀文章.我非常喜欢 Ana Tudor 写的教程.在她的教程中有大量使用 SVG 制作的图解以及实时交互 DEMO,可以说教程的所有细枝末节 ...

  8. TI-RTOS 之 PWM

    TI-RTOS 之 PWM CC1310 有4个定时器,8个PWM通道,在TI-RTOS它的驱动是写好的,引用时需要包含 PWM.h头文件即可. 一般是任务主体之前,或者主函数进行初始化. Board ...

  9. UEP-级联查询

    级联查询在UEP中采用动态下拉的形式,cascadeid为关键字,注意jsp页面的id的相互嵌套关系,数据库字段的数值的设置,和动态下拉SQL语句的书写.本功能实现了省市区的三级联动查询

  10. Win7如何解决telnet不是内部或外部命令的方案!听语音

    Telnet用于远程操作互联网中的设备或终端计算机服务器,可以有效的减少现场操作的麻烦.因为设备或终端是遍布整个省或市,有的甚至是国外,如何高效的处理问题是当务之急,除了telnet还可以ssh使用c ...