写这篇短文主要想详细介绍一下jmeter中取样器、逻辑控制器、前置处理器、后置处理器、定时器、配置元件等,可能看起来比较繁杂,其实里面很多操作是类似的,一篇总结和记录的博客:

jmeter官方用户手册链接:https://jmeter.apache.org/usermanual/get-started.html

jmeter是5.1.1版本;

jmeter优势有:轻量、易持续集成(对命令行命令的执行和轻量)、易实现自动化、基于Java开发的很多插件等;

jmeter中各个部分执行的顺序:

1.配置节点--->2.前置处理器--->3.定时器--->4.采样器--->5.后置处理器--->6.断言--->7.监听器;(后面三个器件在采样器运行有结果后才会执行)

一、jmeter基础设置:

1.jmeter线程组:

主要是通过设置线程组的参数来实现并发,从而进行性能测试,其中黄框内是线程数,蓝框内是实现设置线程数所需时间,绿色框内是循环次数也可选择forever进行持续并发:

2.jmeter中取样器:

下图是在线程组中添加采样器,常用的采样器一般是HTTP Request(接口测试)、JDBC Request(连接操作数据库)、Debug Request(调试脚本和查看参数)等:

下图是HTTP 采样器的一些重要参数:协议、服务名、端口号、请求方法、路径、内容编码,第三个红方框内是关于重定向和连接方式的设置,第四个红框那一栏是请求参数和请求体的设置:

HTTP采样器中高阶的设置是下面图:Retrieve All Embedded Resource(检索所有嵌入式资源)是在网页请求有重定向时需要选中的;

3.jmeter中逻辑控制器:

jmeter中逻辑控制器主要是起到控制采样器的作用,实现循环、判断等逻辑结构,常用的逻辑控制器有If Controller(if判断)、Loop Controller(循环)、Transaction Controller(事务)等:

下面是Loop循环控制器,功能和设置与线程组循环控制一样:

一次控制器,只执行一次的的逻辑控制器并没有设置项,可作为登录控制,只登陆一次,后面在利用循环和判断控制器执行其他:

4.jmeter中前置、后置处理器:

前置处理器中常用的有User Parameters(用户参数)、JDBC PreProcessor(数据库)、Bean shell(写代码):

后置处理器常用的是Regular(正则提取)、Xpath(XML文件提取)、Bean shell(代码):

Bean Shell后置处理器,其中语法类似java,可以导包设置变量调用函数等:

5.jmeter中定时器:

6.jmeter中配置元件

配置元件使用还是很频繁的,可以进行各种默认和初始化的参数设置,进行缓存和cookies值的设置等:

7.jmeter监听器:

监听器中常用的有查看结果树、聚合报告等,不同监视器只是对服务响应的不同展示,根据自己的需求进行选择合适的监听器,对其中的参数进行分析:

聚合报告:可以查看并发采样的具体响应参数:采样个数(线程数*循环次数*采样器个数)、错误error率、吞吐量(Throughput,每秒或者没分钟处理的请求个数)、请求和接收的数据大小每秒等;

查看结果树:可以查看发送的请求数据、响应数据和结果,还可以不同格式查看和保存到本地等;

二、jmeter中的参数化:

1.可以通过配置元件或者测试计划中添加UDV(User Defined Variables),无作用域限制的全局变量:

2.可以通过引入前置处理器或者配置元件设置参数:

2.1 前置处理器中添加User Parameters:

2.2 可以添加配置元件中的CSV Data Config进行表格读取参数,也可以用函数__CSV Read进行读取CSV文件将其设置为变量:

CSV Data设置配置有:文件名或者路径、编码方式、变量名(用英文逗号,隔开)、在文件末尾(EOF)进行循环等:

三、jmeter中的关联:

jmeter中的关联主要是获取采样器中动态的数据,将其传入下一个采样器中进行处理,一般获取动态元素用到后置处理器的正则匹配提取器和Xpath(XML格式)处理器:

提取一个Body中的token值将其设置为jmeter中的变量,可通过${token}进行使用。

四、jmeter中的分布式:

在单机进行压力测试时,解决压力不够或者单机压测效果不理想等问题时会用到分布式压测,需要多台电脑进行压测,其中需要一台控制,多台工作:

1.注意事项:

相同版本的jmeter和JDK;关闭杀毒软件;在同一子网下;

2.实现jmeter分布式压测框架图:

3.实现步骤:

(1)在所有slaves上启动jmeter-server;

(2)在master控制机的配置文件上把slaves的ip地址添加到remote_hosts=[ip1,...,ip5],然后重启master上的jmeter;

(3)在master上的jmeter启动测试脚本,查看监听器的结果;

————————————————————————————————————————————————————

jmeter中BeanShell可以写代码实现一些参数的设置和获取,jmeter还用很多扩展的插件能够实现不同需求的测试;

jmeter使用小结的更多相关文章

  1. 性能测试工具——Jmeter使用小结(一)

    Apache Jmeter是针对Java的一款性能测试工具,利用该工具可以实现自动化的批量测试和结果聚合,适合做接口压测.今天就来捋一捋软件安装的一些小细节和使用. 一.安装 Jmeter基于JDK, ...

  2. jmeter接口测试小结

    摘自:http://www.cnblogs.com/houzhizhe/p/6839736.html JMeter做http接口压力测试 测前准备 用JMeter做接口的压测非常方便,在压测之前我们需 ...

  3. jmeter常见问题小结

    1,报500,查看信息头中的Content-Type 2,https的端口号是443 3,同一个线程组中,不同请求分别用到的字段都可以直接写在‘HTTP信息头管理器’中 4,Debug Sampler ...

  4. jmeter使用小结(一)

    jmeter是用来做接口压力测试的工具.这里只是简单介绍一下使用,大家可以自行查看帮助文档, 1.打开jmeter工具,创建线程组任务 2.添加配置元件,根据需要选择设置 3.添加采样器,这里是htt ...

  5. jmeter linux使用经验小结

    1. 确认务必安装了JDK,并且把路径配置OK.否则执行会报错. 2. 当做负载机时,在hosts 配置上    你的ip   你的hostname  或者使用./bin/jmeter-server ...

  6. JMeter入门使用指南

    初识JMeter 最近开始接触和使用JMeter进行性能测试,也是因为工作需要,不得不学习更多新技能,在此之前一直使用LR进行WEB系统的压力测试,但是在ZK开发的WEB系统,我选择使用JMeter. ...

  7. JMeter学习(十九)JMeter测试MongoDB

    JMeter测试MongoDB性能有两种方式,一种是利用JMeter直接进行测试MongoDB,还有一种是写Java代码方式测试MongoDB性能. 第一种方法 1.编写Java代码,内容如下: pa ...

  8. JMeter学习参数化User Defined Variables与User Parameters

    偶然发现JMeter中有两个元件(User Defined Variables与User Parameters)很相近,刚开始时我也没注意,两者有什么不同.使用时却发现两者使用场景有些不同,现在小结一 ...

  9. 【jmeter】关联-正则表达和xpath

    话说LoadRunner有的一些功能,比如:参数化.检查点.集合点.关联,Jmeter也都有这些功能,只是功能可能稍弱一些,今天就关联来讲解一下. JMeter的关联方法有两种:后置处理器-正则表达式 ...

随机推荐

  1. 第08组 Beta版本演示

    简介 组名:955 组长博客:点这里! 成员 031702329庄锡荣(组长) 031702309林晓锋 031702309侯雅倩 031702311陈珊珊 171709030吴珂雨 03170231 ...

  2. 使用CSS隐藏元素滚动条

    如何隐藏滚动条,同时仍然可以在任何元素上滚动? 首先,如果需要隐藏滚动条并在内容溢出时显示滚动条,只需要设置overflow:auto样式即可.想要完全隐藏滚动条只需设置overflow:hidden ...

  3. [技术博客]ubuntu+nginx+uwsgi+Django+https的部署

    ubuntu+nginx+uwsgi+Django+https部署文档 配置机器介绍 操作系统:Ubuntu 18.04.2 LTS 64位 python版本:Python 3.6.7 Django版 ...

  4. es6 Decorator修饰器

    1.类的修饰: 修饰器(Decorator)函数,用来修改类的行为.修饰器是一个对类进行处理的函数.修饰器函数的第一个参数,就是所要修饰的目标类. @testable class MyTestable ...

  5. centos7 安装hadoop2.7.6(分布式)

    本文只做简单介绍,具体步骤操作请参考centos6.5 安装hadoop1.2.1亲测版 本篇只简单介绍安装步骤 1.安装目录 /usr/local/hadoop (HADOOP_HOME) 2,创建 ...

  6. Atlassian JIRA 插件开发之一 环境搭建

    参考 https://developer.atlassian.com/server/framework/atlassian-sdk/  download the SDK 说明 Download the ...

  7. mke2fs和mkfs命令使用

    1.mke2fs命令 在Linux系统下,mke2fs命令可用于创建磁盘分区上的”ext2/ext3”文件系统. (1)语法 mke2fs(选项)(参数) (2)常用选项 -b<区块大小> ...

  8. Debian Stretch升级当前最新稳定版内核

    Why update kernel ? Update the kernel to new version fixed some newer hardware has no driver softwar ...

  9. Linux学习笔记之Linux磁盘及文件系统管理笔记

    Linux磁盘及文件系统管理 CPU,memory(RAM),I/O i/o: disks,ehtercard disks:持久存储数据 接口类型: IDE(ata): 并口,133MB/s;并行总线 ...

  10. asp.net core mvc 集成miniprofiler

    原文:asp.net core mvc 集成miniprofiler asp.net core mvc 集成miniprofiler 一.环境介绍 二.监控asp.net 页面 三.监控执行的sql语 ...