Jmeter组件分类说明

  • Jmeter的组件可以放在任意位置

  • 线程池:用于创建线程。每个线程会"批次顺序"执行任务,因此后面的任务可根据前面的任务决定具体的操作。

          1. 普通线程组(主线程组):用于创建主要的线程任务

          2. setUp线程组: 在普通线程组之前触发,用于做测试的前置操作,例如创建测试账户

          3. tearDown线程组: 在普通线程组之后触发,用于做测试的后置操作,例如清理工作。

  • 取样器:用来模拟http,tcp请求。取样器父节点需要包含线程组,否则不会执行

  • 前置处理器: 用于定义取样器前置操作,例如定义用户生成,JDBC操作。

  • 后置处理器:用于解析取样器结果,父节点需包含取样器。

  • 断言:用来判断取样器结果,父节点需包含取样器。

  • 定时器:用于控制并发请求的频率。当父节点为取样器,只对父节点生效。当父节点为线程组,对整个线程组生效。

  • 配置元件:用于配置公共数据,可被同级节点或同级节点的子节点引用

  • 监听器:用于统计测试结果,形成图表。常用的有察看结果树,汇总报告,聚合报告。可通过安装Plugins Manager来丰富监听器的类型。

  • 假如想查看每个分类的详细说明,可以查看:倔强的潇洒小姐

火焰图

Java+Jmeter+火焰图+Macos 举栗

操作流程

  • 启动Java后台项目, 9999端口,api为http://localhost:9999/v1/searchsrv/all/activities?value=1。请使用控制台启动。例如
# 记住包名
java -jar mockserver.jar
# api 返回值结构为
#{
# "error": null,
# "result": {},
# "success": true
#}
#在macos上,启动火焰图,并追踪到mockserver
#需要下载上面那个火焰图工具
./createFlameGraph.sh mockserver
  • 启动Jmeter,添加线程组


  • 线程组右键->配置原件->http请求默认值,协议http,服务名称localhost,端口号9999

  • 线程组右键->配置原件->用户自定义的变量

  • 线程组右键->取样器->http请求。

    • 协议,服务器名称,端口号都置空,会自动获取http请求默认值
    • 参数取了用户自定义的变量

  • http请求右键添加->断言->json断言->用于判断api返回是否正确。不添加默认只有http code 200认为是正确的

  • 线程组右键添加->监听器->察看结果树->用于查看各个api的详细执行结果.也可以添加在http取样器下面,单独监听。

  • 线程组右键添加->监听器->汇总报告->用于查看各个api汇总的结果,也可添加在http取样器下面,单独监听。

Jmeter查看查看结果

  • 通过察看结果树查看请求是否成功,自定义变量是否生效,JSON断言是否生效

  • 通过汇总报告查看请求汇总情况

火焰图查看调用堆栈

  • Jmeter接口循环多跑几次
  • 停止Java项目
  • 在火焰图工具目录下找到最新的svg文件,使用浏览器打开

更丰富多彩的图形展示

jmeter虽然在可视化界面运行时能有很多图形界面,但是开启了会影响性能。所以建议使用命令行跑,然后生成一个html的页面

下面提供一个脚本,每次运行会根据时间生成一个目录,并将可视化界面生成到目录下。使用的时候需要修改resultPath(结果路径),sciptFile(脚本路径)

  • 可视化 CLI 模式
#设置结果集记录
time_now=`date "+%Y-%m-%d_%H_%M_%S"`
resultPath=/Users/hehe/performanceTest/localRun/result/${time_now} logPath=${resultPath}/log
samplePath=${resultPath}/sample
reportPath=${resultPath}/report
mkdir ${resultPath}
mkdir ${logPath}
mkdir ${samplePath}
mkdir ${reportPath} #设置脚本路径
scriptFile=/Users/hehe/performanceTest/localRun/script.jmx
#设置jmeter路径
jmeterPath=/Users/klook/SoftwareInit/apache-jmeter-5.1.1/bin/jmeter
sh ${jmeterPath} -n -t ${scriptFile} -l ${samplePath}/result.jtl -j ${logPath}/result.log -e -o ${reportPath}
  • 参数说明
-n: 指定 Jmeter 使用 CLI 模式运行
-t: 指定编写完成的测试计划脚本( jmx 文件)
-l: 指定记录样本结果的 JTL 文件的名称
-j: 指定 Jmeter 运行日志输出文件
-r: 在指定的服务器(JMeter property "remote_hosts")上运行测试计划
-R: 在指定的多个远程服务器上运行测试计划
-g: 仅生成报告仪表盘
-e: 测试完成后生成报告仪表板
-o: 指定测试报告输出的位置,文件夹不得存在或为空
-H: 指定代理服务器主机名或IP地址
-P: 指定代理服务器端口

易踩坑

因为同一个线程组的任务是顺序执行的,所以同一个线程组中,频率最低的任务是所有任务的瓶颈。例如A->B,A每分钟60次,B每分钟120次,实际B为每分钟60次

Java性能测试从入门到放弃-详解篇的更多相关文章

  1. Java性能测试从入门到放弃-概述篇

    Java性能测试从入门到放弃-概念篇 辅助工具 Jmeter: Apache JMeter是Apache组织开发的基于Java的压力测试工具.用于对软件做压力测试.JMeter 可以用于对服务器.网络 ...

  2. 【转】JSch - Java实现的SFTP(文件下载详解篇)

    上一篇讲述了使用JSch实现文件上传的功能,这一篇主要讲述一下JSch实现文件下载的功能.并介绍一些SFTP的辅助方法,如cd,ls等.   同样,JSch的文件下载也支持三种传输模式:OVERWRI ...

  3. JSch - Java实现的SFTP(文件下载详解篇)

    上一篇讲述了使用JSch实现文件上传的功能,这一篇主要讲述一下JSch实现文件下载的功能.并介绍一些SFTP的辅助方法,如cd,ls等. 同样,JSch的文件下载也支持三种传输模式:OVERWRITE ...

  4. JSch - Java实现的SFTP(文件下载详解篇)(转)

    上一篇讲述了使用JSch实现文件上传的功能,这一篇主要讲述一下JSch实现文件下载的功能.并介绍一些SFTP的辅助方法,如cd,ls等.   同样,JSch的文件下载也支持三种传输模式:OVERWRI ...

  5. java线程池的使用与详解

    java线程池的使用与详解 [转载]本文转载自两篇博文:  1.Java并发编程:线程池的使用:http://www.cnblogs.com/dolphin0520/p/3932921.html   ...

  6. 牛客网 Java 工程师能力评估 20 题 - 详解

    牛客网 Java 工程师能力评估 20 题 - 详解 不知在看博客的你是否知道 牛客网,不知道就太落后了,分享给你 : 牛客网 此 20 题,绝对不只是 20 题! 免责声明:本博客为学习笔记,如有侵 ...

  7. Java性能分析之线程栈详解与性能分析

    Java性能分析之线程栈详解 Java性能分析迈不过去的一个关键点是线程栈,新的性能班级也讲到了JVM这一块,所以本篇文章对线程栈进行基础知识普及以及如何对线程栈进行性能分析. 基本概念 线程堆栈也称 ...

  8. Java 中的异常和处理详解

    Java 中的异常和处理详解 原文出处: 代码钢琴家 简介 程序运行时,发生的不被期望的事件,它阻止了程序按照程序员的预期正常执行,这就是异常.异常发生时,是任程序自生自灭,立刻退出终止,还是输出错误 ...

  9. 经典Spring入门基础教程详解

    经典Spring入门基础教程详解 https://pan.baidu.com/s/1c016cI#list/path=%2Fsharelink2319398594-201713320584085%2F ...

随机推荐

  1. hdu6383 p1m2(二分答案)

    p1m2 题目传送门 解题思路 因为x都是非负数,且每一次操作其实就是把总和减少了1,所以可以得出最后都可以到达稳定.最后稳定的数的下界是0,最大也不会超过其初始数的最大值,所以可以用二分答案来求解. ...

  2. 给hexo添加宠物

    开始 之前在博客园上看到,公告栏里有人竟然在养鱼,觉得很好玩!一直念念不忘的,于是就想着在hexo中也来养几只,因为我用的事Next的Muse主题,所以有一个非常合适的侧边栏,先来看看效果. 点击此处 ...

  3. Java EE.JSP.内置对象

    JSP根据Servlet API 规范提供了某些内置对象,开发者不用事先声明就可以使用标准的变量来访问这些对象.JSP提供了九中内置对象:request.response.out.session.ap ...

  4. 第二篇:"空空如也"的博客应用

    文中涉及的示例代码,已同步更新到 HelloGitHub-Team 仓库 建立博客应用 我们已经建立了 django 博客的项目工程,并且成功地运行了它.不过到目前为止这一切都还只是 django 为 ...

  5. python网络爬虫(14)使用Scrapy搭建爬虫框架

    目的意义 爬虫框架也许能简化工作量,提高效率等.scrapy是一款方便好用,拓展方便的框架. 本文将使用scrapy框架,示例爬取自己博客中的文章内容. 说明 学习和模仿来源:https://book ...

  6. 在Linux - Centos上安装Python3(上)

    必看内容 在Linux上安装Python常用的2种方法 1.Python源码编译安装,有点复杂,适合老司机 2.从EPEL/IUS仓库安装,新手建议使用些方法,比较简单,目前2019-07-31提供最 ...

  7. Java性能权威指南读书笔记--之二

    新生代填满时,垃圾收集器会暂停所有的应用线程,回收新生代空间.这种操作被称为Minor GC. 老年代被填满时,垃圾收集器会暂停所有应用线程,对其进行回收,接着对堆空间进行整理.这个过程被称为Full ...

  8. 夯实Java基础(六)——包装类

    1.包装类简介 我们都知道Java是面向对象编程语言,包含了8种基本数据类型,但是这8种基本数据类型并不支持面向对象的特征,它们既不是类,也不能调用方法.这在实际使用时存在很多的不便,比如int类型需 ...

  9. DesignPattern系列__10单例模式

    单例模式介绍 单例模式,是为了确保在整个软件体统中,某个类对象只有一个实例,并且该类通常会提供一个对外获取该实例的public方法(静态方法). 比如日志.数据库连接池等对象,通常需要且只需要一个实例 ...

  10. 浅谈NodeJS多进程服务架构基本原理

    阅读目录 一:nodejs进程进化及多进程架构原理 二:node中child_process模块实现多进程 三:父子进程间如何通信? 四:理解cluster集群 回到顶部 一:nodejs进程进化及多 ...