一、简单了解

Apache JMeter

The Apache JMeter application is open source software, a 100% pure Java application designed to load test functional behavior and measure performance. It was originally designed for testing Web Applications but has since expanded to other test functions.

官网网站为:

https://jmeter.apache.org/

安装

l 官网:http://jmeter.apache.org/download_jmeter.cg

l 下载完成后直接解压缩即可,无须安装(前置条件,本机需要有java运行虚拟机环境)。

l 点击bin目录下的jmeter.bat文件即可启动jmeter.

帮助文档:

https://jmeter.apache.org/usermanual/get-started.html

插件安装

访问:https://jmeter-plugins.org/install/Install/

下载后存放位置:

1) 下载成功后将jar包放到jmeter的 lib/ext目录下,重启jmeter即可

2) 验证插件可以使用

查看插件

二、初步功能测试介绍

步骤一:新建线程组 【Thread Group】

步骤二:添加请求类型【sampler】

步骤三:增加结果参看树【view results tree】

1、添加线程组

TestPlan-->右键-->add-->Threads(Users),添加Thread Group

解释:Threads(Users):

  1. setUp Thread Group
  2. tearDown Thread Group

这个两个组件在工作中不是必须的,setUp Thread Group用来做初始化的工作,Thread Group是工作常用组;tearDown Thread Group用来做清理工作;

 

2、添加Sampler(演示使用HTTP Request)

选中group,右键-->add-->Sampler-->选择要测试的协议类型,以HTTP Request为例

显示:

说明:

Protocol[http]:不写就是默认的HTTP

Server Name or IP:www.7dtest.com 【默认不需要带http://】
Port Number:HTTP默认为80
Path:/表示根目录
Paramters:分两种方式一种为key-->value与json两种方式
 
3、添加查看结果

选中TestPlan-->右键-->add-->Listener-->View Results Tree,

点击请求:

弹出警告:

为你是否保存之后运行

结果如下:

结果查看几种方式:

View Results Tree组件可以很方便的查看请求的数据,响应的数据,当出现问题的时候可以用来分析问题,在jmeter中使用的频率很高

  1. Write results to file/Read from file

Filename:可以将执行结果保存到Filename指定的文件中,注意:默认保存在jmeter的bin目录下。如果勾选了后面的Errors,那么只保存错误信息;如果勾选了Success,那么只保存执行成功的信息;都不勾选的话保存所有的信息

l Browser:可以打开之前保存过的测试文件,将测试信息显示到下面的result栏中。如果勾选了后面的Errors,那么只显示错误信息;如果勾选了Success,那么只显示执行成功的信息;都不勾选的话显示所有的信息

1、Text:默认的显示方式,原始的HTML文本

2、HTML:以类似浏览器的格式查看响应数据

3、RegExp Tester:支持正则用来做检查点或者关联使用

如:<title>(.*?)</title>

[1][0]:表示整个匹配的表达式

[1][1]:表示分组中的内容

4、XPath Tester:xpath方式提取内容

参考语法:[https://www.w3school.com.cn/xpath/index.asp]

l Use Tidy?:当需要处理的页面是HTML格式时,必须选中该选项,当需要处理的页面是XML或XHTML格式(例如,RSS返回)时,取消选中该选项。l Reference Name:存放提取出的值的参数。l XPath Query:用于提取值的XPath表达式。l Default Value:参数的默认值

5、JSON PATH Tester 使用方式为:

如果:$.extend.pageInfo.pageSize

参考java代码如:

 /**   
* 通过json获取值
 
    * 李文 2020-03-25

* @param json

* @param path

* @param filter

* @return

*/
public static Object jsonPath(String json, String path, Filter... filter) {

try {

return filter.length == 0 ? JsonPath.parse(json).read(path, new Predicate[0]) : JsonPath.parse(json).read(path, new Predicate[]{filter[0]}); }
catch (PathNotFoundException var4) {

log.error(var4.getMessage());

return null;

}

}

以上取值待遇也是按$.开头取值;

6、Scroll automatically:请求很多时可以自动滚屏

如果勾选会自动滚屏

View Results Tree试图为:

sampler result:

说明:

Thread Name: Thread Group 1-1:Thread Group 2线程组的编号,1是线程组内线程的编号

Load time: 整个请求的执行时间

Connect Time: 连接时间

Latency: 延迟时间

Size in bytes: Headers size in bytes + Body size in bytes

Sent bytes:发送的字节数

request 请求数据

response data  响应数据

聚合报告简单说明使用

图:

运行结果:

说明:

  1. Label:标签。如果选择了Include group name in label?这个选项,就会添加线程组的名称作为前缀(当聚合报告监控多个线程组时就勾上)

  2. Samples:具有相同名称的样本数

  3. Average:平均响应时间(单位:毫秒),默认是单个request的平均响应时间,当使用了事务控制器(Transaction Controller)的时候,也可以以事务为单位统计响应时间

  4. Median:中位数。也就是50%的样本不超过这个时间

  5. 90% Line:90%的样本不超过这个时间

  6. 95% Line:95%的样本不超过这个时间

  7. Min:具有相同标签样本的最小执行时间

  8. Maximum:具有相同标签样本的最大执行时间

  9. Error %:错误百分比

  10. Throughput:吞吐量,一般认为是TPS。吞吐量以每秒/分钟/小时的请求量来衡量。当TPS很低时,jmeter会默认以分钟为单位统计。

  11. Received KB/Sec:每秒收到的以千字节为单位的吞吐量

  12. Sent KB/Sec:每秒发送的以千字节为单位的吞吐量

  13. Save Table Data:把数据保存到csv文件中

  14. Include group name in label?:会将线程组的名字作为前缀显示

打开文件如:

简单说明:

改图配置可以根据实际情况选择

性能工具之Jmeter小白入门系列之一的更多相关文章

  1. 性能工具之JMeter+InfluxDB+Grafana打造压测可视化实时监控【转】

    概述 本文我们将介绍如何使用JMeter+InfluxDB+Grafana打造压测可视化实时监控. 引言 我们很多时候在使用JMeter做性能测试,我们很难及时察看压测过程中应用的性能状况,总是需要等 ...

  2. 性能工具之JMeter+InfluxDB+Grafana打造压测可视化实时监控

    一.安装配置InfluxDB InfluxDB是GO语言开发的一个开源分布式时序数据库,非常适合存储指标.事件.分析等数据.有人做过mysql和influxDB对比,存储1000万条数据mysql要7 ...

  3. 性能工具之Jmeter压测Hprose RPC服务

    概述 Hprose(High Performance Remote Object Service Engine),国人开发的一个远程方法调用的开源框架.它是一个先进的轻量级的跨语言跨平台面向对象的高性 ...

  4. 性能工具之Jmeter压测Thrift RPC服务

    概述 Thrift是一个可互操作和可伸缩服务的框架,用来进行可扩展且跨语言的服务的开发.它结合了功能强大的软件堆栈和代码生成引擎,以构建在 C++, Java, Python, PHP, Ruby, ...

  5. 性能工具之JMeter+InfluxDB+Grafana打造压测可视化实时监控(centos7环境)

    前提条件,已经安装jmeter并可以运行 1.安装influxdata wget et https://dl.influxdata.com/influxdb/releases/influxdb-1.7 ...

  6. Redis小白入门系列

    一.从NoSQL说起 NoSQL 是 Not only SQL 的缩写,大意为"不只是SQL",说明这项技术是传统关系型数据库的补充而非替代.在整个NoSQL技术栈中 MemCac ...

  7. 小白入门NAS—快速搭建私有云教程系列(一)

    什么是NAS 在日常的工作生活中,我们有大量的资料.文件需要存储在电脑或者其他终端设备中,但是这种方式需要电脑配备高容量的硬盘,而且需要随时随地的带着,这样是不是很麻烦? 那么,今天,我来介绍一种家庭 ...

  8. webpack 快速入门 系列 —— 性能

    其他章节请看: webpack 快速入门 系列 性能 本篇主要介绍 webpack 中的一些常用性能,包括热模块替换.source map.oneOf.缓存.tree shaking.代码分割.懒加载 ...

  9. 【Go语言入门系列】Go语言工作目录介绍及命令工具的使用

    [Go语言入门系列]前面的文章: [保姆级教程]手把手教你进行Go语言环境安装及相关VSCode配置 [Go语言入门系列](八)Go语言是不是面向对象语言? [Go语言入门系列](九)写这些就是为了搞 ...

随机推荐

  1. 深入浅出带你玩转sqlilabs(一)

    一.MySQL数据库结构分层 1.1库名,表名,列名,数据库用户等 Mysql数据库结构示例: 数据库A zblog = www.zblog.com 表名 列名(字段) 数据 数据库B dede = ...

  2. sharding JDBC 不支持批量导入解决方法

    package com.ydmes.service.impl.log; import com.ydmes.domain.entity.log.BarTraceBackLog;import org.sp ...

  3. .NET Design Patterns

    设计模式分组 GoF设计模式著作中的23种设计模式分为3组:创建型(Creational).结构型(Structural)和行为型(Behavional). 创建型 创建型处理对象构造和引用.它们将对 ...

  4. spring源码解析之属性编辑器propertyEditor

    异常信息造成此异常的原因bean配置文件调用代码特别说明:异常解决注册springt自带的属性编辑器 CustomDateEditor控制台输出属性编辑器是何时并如何被注册到spring容器中的?查看 ...

  5. 没有发生GC也进入了安全点?这段关于安全点的JVM源码有点意思!

    文末 JVM 思维导图,有需要的可以自取 熟知并发编程的你认为下面这段代码的执行结果是怎么样的? 我如果说,执行流程是: t1 线程和 t2 线程一直执行 num 的累加操作 主线程睡眠 1 秒,1 ...

  6. Alpha事后分析

    设想和目标 1. 我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述? 我们的软件的功能主要是让一些基于表单识别的项目(如微软智能表单识别项目)减少在数据生成方面上浪费的 ...

  7. 利用stat指令查看文件创建时间

    -shroot@test-W330-C30:/# stat * 文件:'b' 大小:4096 块:8 IO 块:4096 目录设备:802h/2050d Inode:5636097 硬链接:2权限:( ...

  8. k8s集群部署(2)

    一.利用ansible部署kubernetes准备阶段 1.集群介绍 基于二进制方式部署k8s集群和利用ansible-playbook实现自动化:二进制方式部署有助于理解系统各组件的交互原理和熟悉组 ...

  9. 1.2Linux 主要目录速查表

    Linux 主要目录速查表 /:根目录,一般根目录下只存放目录,在 linux 下有且只有一个根目录,所有的东西都是从这里开始 当在终端里输入 /home,其实是在告诉电脑,先从 /(根目录)开始,再 ...

  10. Java求余%引发的一连串故事

    C1 RCE对%的处理 HotSpot VM的C1有个RCE(Range Check Elimination,范围检查消除)优化,所谓范围检查消除,就是为了正确的抛出数组越界异常,虚拟机需要在数组访问 ...