JMeter的使用——傻瓜式学习【下】

目录

前言

1、自动录制脚本

1.1、原理

 1.2、JMeter脚本录制

2、JMeter直连数据库

2.1、直连数据库的作用

2.2、JMeter直连数据库的步骤

案例:

3、JMeter的逻辑控制器

3.1、if控制器

案例:

3.2、循环控制器

案例:

3.3、ForEach控制器

案例:使用用户自定变量~

4、JMeter的定时器

4.1、同步定时器

案例:

4.2、常数吞吐量定时器

案例:

4.3、固定定时器

案例:


前言

        JMeter学习上:http://t.csdnimg.cn/DOWpY

        JMeter学习中:http://t.csdnimg.cn/sLJ99


1、自动录制脚本

1.1、原理

        JMeter录制脚本,在没有接口文档的旧项目中,快速录制web页面产生的http接口请求,帮助编写接口测试脚本。

JMeter录制脚本原理:

正常请求过程:

JMeter录制过程:

 1.2、JMeter脚本录制

步骤一:添加http代理服务器,并进行配置

加http代理服务器:

配置代理服务器的参数:

步骤二:开启Windows操作系统的浏览器代理

 步骤三:启动代理服务器:

然后去,浏览器操作,有的可能要在Chrome浏览器,有的是IE,你都试试,看哪个能抓到:

我这边是Chrome浏览器,我浏览了我本机服务器下的一个博客系统的网页,如下:

我们这就是成功了~

我们可以看到上面有很多是css文件js文件,我们不想获取这类的文件,可以在http代理服务器的配置中做如下修改:

 包含就是:匹配则抓取;排除模式:匹配则丢弃【不抓取】~


2、JMeter直连数据库

2.1、直连数据库的作用

  1. 用作请求的参数化。例如:登录时需要的用户名,可以从数据库中查询获取
  2. 用作结果断言。例如:添加购物车下订单,检查接口返回的订单号,是否与数据库中生成的订单号一致
  3. 清理垃圾数据。例如:添加商品时(添加商品编号不能重复),重复时执行该脚本不能成功,需要在下次执行前删除该商品数据(取消添加)
  4. 准备测试数据。例如:通过数据库来准备大量的(几十万条)的性能测试数据

2.2、JMeter直连数据库的步骤

        我们先要准备一个MySQL驱动包,我们在MySQL官网中下载即可,下载jar的版本最好和你使用的MySQL的版本一致~下载后,是得到一个压缩包,你解压缩后里面就有一个jar包了~

步骤一:添加MySQL驱动jar包

方式一:在测试计划面板点击:浏览..按钮,将你的JDBC驱动添加进来

方式二:将MySQL驱动jar包放入到lib/ext目录下,重启JMeter

步骤二:配置数据库连接信息

位置:

参数介绍:

  • Variable Name for created pool:MySQL数据库连接池名称(JDBC请求时要引用,自己命名)
  • Database URL:jdbc:mysql://localhost:3306/cnblog【协议 + 数据库IP + 数据库端口 +连接的数据库名,例我这里,协议是jdbc:mysql,数据库IP是本机,端口3306,数据库名是cnblog】
  • JDBC Driver class:com.mysql.jdbc.Driver【下拉框】
  • Username:root【连接的数据库用户名,如实填写】
  • Password:****【连接的数据库密码,如实填写,密码为空就不写】

如下:

步骤三:添加JDBC请求

位置:

添加:

参数介绍:

  • Variable Name:数据库连接池的名字,就是上面你自己命名的那个名字
  • Query Type:自己选择是什么操作,有:增删改查~
  • Query:填写SQL语句,末尾不要";"
  • Variable names:保存sql语句返回结果的变量名

案例:

        我刚才的JDBC连接配置的就是我本机数据库中的cnblog库,所以我们就使用这个库,这个库中有一张用户表,我们现在来查查这张表有多少个用户吧~

步骤:

  1. 添加一个线程组
  2. 添加JDBC Connection Configuration
  3. 添加JDBC request
  4. 添加一个正则表达式,取结果
  5. 添加http请求
  6. 添加查看结果树
  7. 运行看结果

这个请求数据不对,我们添加一个调试取样器,来看看,到底有没有值:

重新运行看看:

所以我们来修改一下请求中的变量:

运行看结果:

成功~ 


3、JMeter的逻辑控制器

3.1、if控制器

作用:if控制器用来控制指定的测试元素是否运行

位置:

参数说明:

  • Expression (must evaluate to true or false) :表达式(值必须是true或false),也就是说,在右边文本框中输入的条件值必须是true 或 false,(默认情况下)
  • Interpret Condition as Variable Expression?:默认勾选项,将条件解释为变量表达式(expression中不能直接填写条件表达式,需要借助函数将条件表达式计算为true/false,可以借助的函数有_jexl3和_groovy)【选中这一项时表示:判断变量值是否等于字符串true(不区分大小写)】【不选中:直接输入我们需要判断的表达式即可,判断表达式为真时,执行if控制器下的请求,例如“1!=2”,则一定会执行下面的http请求】
  • Evaluate for all children?:条件作用于每个子项,执行每个子项,都会判断一次条件。一般不勾选,条件一般只判断一次即可

解释:

  • 上面有一个黄色感叹号,就是提示你使用__jexl3 or __groovy 表达式,以提高性能,也就是默认的方式
  • jexl全称:Jakarta Commons Jexl,是一种表达式语言(Java Expression Language)解释器

举例1,直接输入我们需要判断的表达式:

举例2,使用函数:

案例:

步骤:

  1. 创建一个线程组
  2. 创建一个用户定义的变量,在这里添加一个变量,名为title,值为百度
  3. 创建一个if控制器,和上面的步骤一样,在函数中生成,复制过来,比较title值等不等于百度
  4. 在if控制器下创建一个http请求【if为真请求可发送,为假,请求不发送】
  5. 创建一个查看那结果树

目录结构:

 运行看结果:

你可以尝试修改值,不相等时,请求就不会发送了~

3.2、循环控制器

位置:

参数都是中文就不介绍了~

案例:

  1. 添加一个线程组
  2. 添加一个循环控制器,循环次数设置为3
  3. 在上面这个循环控制器下面添加一个http请求
  4. 添加一个表格查看结果树

目录结构:

运行结果:

3.3、ForEach控制器

        作用:一般和用户自定义变量或者正则表达式提取器一起使用,读取返回结果中一系列相关的变量值。该控制器下的取样器都会被执行一次或多次,每次读取不同的变量值。

位置:

参数介绍:

  • 输入变量前缀:要读取的输入变量的固定前缀
  • Start index for loop(exclusive):开始循环字段(不包含)。要读取的输入变量后缀数字的最小值-1
  • End index for loop(inclusive):结束循环字段(包含)。要读取的输入变量后缀数字的最大值
  • 输出变量名称:读取输入变量的值后保存的新变量名,用于后续http请求来引用~

案例:使用用户自定变量~

步骤:

  1. 添加一个线程组
  2. 添加一个用户定义的变量:
  3. 添加foreach循环器:
  4. 在控制器下面添加一个http请求:
  5. 添加生成结果树

目录结构:

运行结果:

例如查看第5个请求:


4、JMeter的定时器

4.1、同步定时器

        同步定时器:阻塞线程(累计一定的请求),当在规定时间内达到一定的线程数量,这些线程会在同一个时间点一起释放,瞬间产生很大的压力。

位置:

参数介绍:

  • Number of Simulated Users to Group by:模拟用户的数量,即指定同时释放的线程数数量。如果设置为0,表示设置为线程组中的线程数量
  • Timeout in milliseconds:超时时间,即超时多少毫秒后同时释放指定的线程数。如果设置为0,表示该定时器将会等待线程数达到了设置的线程数才释放,若没有达到设置的线程数会一直死等;如果设置的值大于0,那么如果超过设置的最大等待时间还没有达到设置的线程数,Timer将不再等待,释放已到达的线程。默认为0.

案例:

步骤:

  1. 添加一个线程组,线程数设置为20
  2. 添加一个http请求
  3. 添加同步定时器,模拟用户数量设置为5,超时为100
  4. 添加一个表格查看结果树

目录:

运行结果:

前五个为一组,几乎是同一时间发送的请求~

4.2、常数吞吐量定时器

作用:可以让线程以一个目标吞吐量去运行

位置:

参数说明:

  • Target throughput (in samples per minute):目标吞吐量(每分钟的样本量)。每分钟的吞吐量
  • Calculate Throughput based on:基于什么计算吞吐量
  • this thread only:只有此线程。控制每个线程的吞吐量,选择这种模式时,总的吞吐量为设置的target Throughput(上面设置的每分钟的吞吐量) 乘以该线程的数量
  • all active threads:所有活动线程。设置的target Throughput 将分配在每个活跃线程上,每个活跃线程在上一次运行结束后等待合理的时间后再次运行。活跃线程指同一时刻同时运行的线程
  • all active threads in current thread group:当前线程组中的所有活动线程。设置的target Throughput 将分配在当前线程组的每一个活跃线程上,当测试计划中只有一个线程组时,该选项和all active threads 选项的效果完全相同
  • all active threads (shared):所有活动线程(共享)。与all active threads的选项基本相同。唯一区别是,每个活跃线程都会在所有活跃线程上一次运行结束后等待合理的时间后再次运行
  • all active threads in current thread group (shared):当前线程组中的所有活动线程(共享)。与all active threads in current thread group 基本相同,唯一的区别是,每个活跃线程都会在所有活跃线程的上一次运行结束后等待合理的时间后再次运行

案例:

步骤:

  1. 添加一个线程组
  2. 添加一个常数吞吐量定时器
  3. 添加一个调试取样器
  4. 添加一个聚合报告

目录结构:

运行结果:

3秒发送了33个请求~ 

4.3、固定定时器

作用:在两个请求之间,第一个请求发送之后等待一段时间再发送第二个请求。

位置:

上面这里设置的延迟时间就是请求1发送后等300毫秒再发后面的请求~

案例:

步骤:

  1. 添加一个线程组
  2. 添加一个http请求1
  3. 添加一个固定定时器,时间设置为3000毫秒,也就是3s
  4. 添加http请求2
  5. 添加一个表格查看结果树

目录结构:

运行观察结果:

相差3秒:

好啦,我们先这里咯,下期见~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/130021.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

22吉林大学软件需求分析与规范(Software Requirements Analysis Specification)

写在前面: 4w多字笔记,可能显示有问题,带图片完整pdf版暂定10r一份,需要的同学可以加wx:fanaobo,备注软件需求笔记。 chapter 0 课程简介 课程简介: ◼ 软件工程专业核心课程之一 ◼ 软件工程课程体系最…

大数据毕业设计选题推荐-热门旅游景点数据分析-Hadoop-Spark-Hive

✨作者主页:IT研究室✨ 个人简介:曾从事计算机专业培训教学,擅长Java、Python、微信小程序、Golang、安卓Android等项目实战。接项目定制开发、代码讲解、答辩教学、文档编写、降重等。 ☑文末获取源码☑ 精彩专栏推荐⬇⬇⬇ Java项目 Python…

基于蜜獾算法的无人机航迹规划-附代码

基于蜜獾算法的无人机航迹规划 文章目录 基于蜜獾算法的无人机航迹规划1.蜜獾搜索算法2.无人机飞行环境建模3.无人机航迹规划建模4.实验结果4.1地图创建4.2 航迹规划 5.参考文献6.Matlab代码 摘要:本文主要介绍利用蜜獾算法来优化无人机航迹规划。 1.蜜獾搜索算法 …

HTTPS的加密方式超详细解读

在了解https的加密方式之前,我们需要先行了解两个特别经典的传统加密方式: 1、对称加密 1.1、定义 需要对加密和解密使用相同密钥的加密算法。所谓对称,就是采用这种加密方法的双方使用方式用同样的密钥进行加密和解密。密钥是控制加密及解…

二叉树采用二叉链表存储:编写计算二叉树最大宽度的算法(二叉树的最大宽度是指二叉树所有层中结点个数的最大值)

二叉树采用二叉链表存储:编写计算二叉树最大宽度的算法 (二叉树的最大宽度是指二叉树所有层中结点个数的最大值) 和二叉树有关的代码,基本都逃不过“先中后层”,这四种遍历 而我们这里是让你计算最大宽度&#xff0c…

如何使用Selenium处理Cookie,今天彻底学会了

📢专注于分享软件测试干货内容,欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正!📢交流讨论:欢迎加入我们一起学习!📢资源分享:耗时200小时精选的「软件测试」资…

【Linux】Nignx的入门使用负载均衡动静分离(前后端项目部署)---超详细

一,Nignx入门 1.1 Nignx是什么 Nginx是一个高性能的开源Web服务器和反向代理服务器。它使用事件驱动的异步框架,可同时处理大量请求,支持负载均衡、反向代理、HTTP缓存等常见Web服务场景。Nginx可以作为一个前端的Web服务器,也可…

VUE2和VUE3思维导图知识体系总结大对比

VUE2知识体系 VUE3知识体系 思维导图原件下载地址

前端难学还是后端难学?系统安全,web安全,网络安全是什么区别?

系统安全,web安全,网络安全是什么区别?三无纬度安全问题 系统安全,可以说是电脑软件的安全问题,比如windows经常提示修复漏洞,是一个安全问题 网页安全,网站安全,比如,…

【t5 pytorch版源码学习】t5-pegasus-pytorch源码学习

0. 项目来源 中文生成式预训练模型,以mT5为基础架构和初始权重,通过类似PEGASUS的方式进行预训练。 bert4keras版:t5-pegasus pytorch版:t5-pegasus-pytorch 本次主要学习pytorch版的代码解读。 项目结构: train…

Unity地面交互效果——3、曲面细分基础知识

大家好,我是阿赵。   之前介绍了使用动态法线贴图混合的方式模拟轨迹的凹凸感,这次来讲一下更真实的凹凸感制作。不过在说这个内容之前,这一篇先要介绍一下曲面细分着色器(Tessellation Shader)的用法。 一、为什么要做曲面细分 之前通过法…

canal+es+kibana+springboot

1、环境准备 服务器:Centos7 Jdk版本:1.8 Mysql版本:5.7.44 Canal版本:1.17 Es版本:7.12.1 kibana版本:7.12.1 软件包下载地址:链接:https://pan.baidu.com/s/1jRpCJP0-hr9aI…

【计算机网络】网络层:数据平面

一.网络层概述 每台路由器的数据平面的主要功能时从其输入链路向其输出链路转发数据报,控制平面的主要功能是协调这些本地的每路由转发动作,使得数据报沿着源和目的地主机之间的路由器路径最终进行端到端传送。 网络层不运行运输层和应用层协议。 转发是…

Pytorch网络模型训练

现有网络模型的使用与修改 vgg16_false torchvision.models.vgg16(pretrainedFalse) # 加载一个未预训练的模型 vgg16_true torchvision.models.vgg16(pretrainedTrue) # 把数据分为了1000个类别print(vgg16_true) 以下是vgg16预训练模型的输出 VGG((features): S…

FFmpeg直播能力更新计划与新版本发布

// 编者按:客户端作为直接面向用户大众的接口,随着技术的发展进化与时俱进,实现更好的服务是十分必要的。FFmpeg作为最受欢迎的视频和图像处理开源软件,被相关行业的大量用户青睐,而随着HEVC标准的发布到广泛使用&am…

【jvm】虚拟机栈

目录 一、背景二、栈与堆三、声明周期四、作用五、特点(优点)六、可能出现的异常七、设置栈内存大小八、栈的存储单位九、栈运行原理十、栈帧的内部结构10.1 说明10.2 局部变量表10.3 操作数栈10.4 动态链接10.5 方法返回地址10.6 一些附加信息 十一、代…

整理10个地推拉新app接单平台,免费一手推广渠道平台干货分享

1. 聚量推客: “聚量推客”汇聚了众多市场上有的和没有的地推网推拉新接单项目,目前比较火热,我们做地推和网推从业者如果长期在这行业去做推广可以使用这个平台,价格高数据也好,大部分拉新项目也都是官签一手资源 一…

关于Intel Press出版的《Bedyong BIOS》第2版的观后感

文章目录 此书的背景UEFI运行时DXE基础CPU架构协议PCI协议UEFI驱动的初始化串口DXE驱动示例 《Beyond BIOS》首先介绍一个简单的UEFI应用程序模块,用于展示UEFI应用程序的行为。作者为Waldo。该模块名为“InitializeHelloApplication”,它接受两个参数&a…

Leetcode—101.对称二叉树【简单】

2023每日刷题(十九) Leetcode—101.对称二叉树 利用Leetcode101.对称二叉树的思想的实现代码 /*** Definition for a binary tree node.* struct TreeNode {* int val;* struct TreeNode *left;* struct TreeNode *right;* };*/ bool isSa…

【深度学习基础】Pytorch框架CV开发(1)基础铺垫

📢:如果你也对机器人、人工智能感兴趣,看来我们志同道合✨ 📢:不妨浏览一下我的博客主页【https://blog.csdn.net/weixin_51244852】 📢:文章若有幸对你有帮助,可点赞 👍…