jemeter安装及使用

1.下载

        地址:Apache JMeter - Download Apache JMeter

          Binaries的意思是发行版。Source是源码,用于二次开发。

2.下载之后解压,进入bin目录,点击jemeter.bat,运行

3.配置环境变量

        新建一个环境变量 变量名JMETER_HOME 变量值:你解压出来的目录
        编辑Path变量 追加一段内容;%JMETER_HOME%\bin

4.设置

       1. 默认英文,可以调整为中文或其他
              步骤: options->choose language->chinese(simplified)

       2.返回结果中文乱码
             jmeter_home/bin 修改配置文件jmeter.properties,加上如下行,然后重启
                      sampleresult.default.encoding=utf-8

2.概念

        执行顺序

        1.测试计划(test plan):

                描述一个性能测试,包含本次测试所有相关功能

        2.线程 threads(users):

                1) Thread group:通常添加使用的线程,一般一个线程组可看做一个虚拟用户组,其中每个线程为一个虚拟用户

                2)Setup thread group:用于执行预测试操作。即执行测试前进行定期线程组的执行

                3)Teardown thread group:用于执行测试后动作。即执行测试结束后执行定期的线程组

           loadrunner的脚本除了action里是真正的脚本核心内容,还有初始化“环境”的初始化脚本和测试完毕后对应的清除信息的脚本块,与其对应

        3. 测试片段(test fragment):

是一种特殊的线程组,在测试树上与线程组一个层级,但是它不被执行,除非它是一个模块控制器或者被控制器所引用时才会被执行

        4.配置原件(Config Element): 

用于提供对静态数据配置的支持。CSV Date Set Config可以将本地数据文件形成数据池(Date Pool),而对应于HTTP Request Configuration和TCP Request Sample等类型的Configuration元件则可以修改这些Sample的默认数据等

        5.前处理器(Pre Processors): 

用于在实际请求发出之前对即将发出的请求进行特殊处理。如:Count处理器可以实现自增操作,自增后生成的的数据可以被将要发出的请求使用,而HTTP URL Re—Writing Modifier处理器则可以实现URL重写,当URL中有sessionID一类的session信息时,可以通过该处理器填充发出请求实际的sessionID。

        6.控制器:

                1)取样器(Sampler): 是性能测试中向服务器发送请求,记录响应信息,记录响应时间的最小单元,JMeter 原生支持多种不同的sampler .如 HTTP Request Sampler 、 FTP  Request Sampler 、TCP  Request Sampler JDBC Request Sampler 等每一种不同类型的 sampler 可以根据设置的参数向服务器发出不同类型的请求。

                2)逻辑控制器(Logic Controller): 包含两类原件:一类是控制Test Plan中Sampler节点发送请求的逻辑顺序控制器,常用的有:If Controller、Swith Controller、Loop Controller、Random Controller等.另一类是用来组织和控制Sampler节点的,如Transaction Controller、Throughput Controller等

        7.定时器(Time): 

用于操作之间设置等待时间,等待时间使性能测试中常用的控制客户端QPS的手段,jmeter定义了Constant Times、Constant Throughput Times、Guass Ramdon Times等不同类型的Times

          8.后处理器(Post Processors):

 用于对Sampler发出请求后得到的服务器响应进行处理。一般用来提取响应中的特定数据(类似loadrunner中的关联)。如:Regular Expression Extractor用于提取响应数据中匹配某正则表达式的数据段,并将其填充在参数中,Xpath Extractor则可以用于提取响应数据中通过给定Xpath值获得的数据。

          9.断言(Assertions): 

用于检查测试中得到的响应数据等是否符合预期,Assertions一般用来设置检查点,用以保证性能测试过程中的数据交互与预期一致

        10.监听器(Listener): 

对测试结果进行处理和可视化展示的一系列组件,常用的有图形结果、查看结果树、聚合报告等

       

        组件的作用域:

        1.组件可作用于兄弟节点下面的子节点

        2.组件可作用于兄弟节点

        3.组件可作用于父节点

3.下载插件管理工具

        1.百度一下jmeter plugins找到Jmeter插件官网,下载plugins-manager.jar,

Install :: JMeter-Plugins.org

        2.下载好了之后,放进Jmeter安装路径的/lib/ext目录下,再重启Jmeter

        3.打开插件管理工具 (选项->Plugins Manager->Available Plugins)

        4.根据需求勾选以下插件:

插件下载地址:  Download :: JMeter-Plugins.org

JMeterPlugins-Extras.jar

jmeter-plugins-manager-1.4.jar

JMeterPlugins-Standard.jar

4.逻辑控制器

事务控制器:

仅一次控制器:

吞吐量控制器:

        based on:

                Percent: 默认。按百分比分配流量

                total: 代表总次数

2.定时器

3.集合点:jemeter叫同步定时器,用于实现并发。

4.压测:

5.混合负载压测场景:

目的是为了验证整个业务的最大的最优的性能体现,重点在于模型的设计,模型来自于数据(来自生产环境的日志或者产品经理给出的)

压测策略,压测场景,压测用例:

this group will start : 启动多少个线程 , 100

first wait for :等待多少秒才开始压测,一般为0

then start: 一开始有多少个线程数,一般为0

-----------------------------------------------------------

next add

threads erevy

using ramp-up

每多少秒启动多少个虚拟用户数,每组数据持续运行多少秒

每5秒启动10个虚拟用户数,每组数据持续运行30秒

then hold load for 60 : 全部加载完后,负载运行60秒

finally stop 5  threads erevy 1 secods : 每一秒停止5个虚拟用户数。

6.压力测试场景

验证系统的极限,直到有任何一个性能指标超出预期。

7.稳定性测试场景

在压力测试的场景下持续运行4-24小时

8.无界面压测

        1.节约系统资源

         2.更快捷,只需要启动命令即可进行压测

        3.主要是用于性能压测集成

                -n   表示无界面压测

                -t     制定你的jmx脚本

                -l      生成jtl测试报告

                注意:jmeter安装目录下,apache-jmeter-5.4.1\bin\jmeter.properties 文件修改以下内容

                jmeter.save.saveservice.output_format=xml

                jmeter.save.saveservice.response_code=true

                jmeter.save.saveservice.samplerData=true

        命令:保存脚本到D盘目录下,CMD到该目录,执行以下命令

                D:

                cd text

                dir

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

        直接生成报告:

                -e  -o

        命令:   jemeter -n -t test.jmx -l result.jtl -e -o reports

                注意:

                  jmeter.save.saveservice.output_format=csv

        

        很重要的两个参数: 用于分布式集群压测

        -r   表示启动所有的远程压力机执行压测

        -R   指定特定的远程压力机执行压测,多台用逗号  ,  隔开

        命令:  

                 jemeter -n -t test.jmx -l result.jtl -e -o reports -r

                 jemeter -n -t test.jmx -l result.jtl -e -o reports -R 127.0.0.1

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值