开源性能测试工具JMeter快速入门(一)

本文涉及的产品
性能测试 PTS,5000VUM额度
简介:

目录

一、JMeter简介

二、JMeter功能介绍

三、JMeter脚本

四、关于JMeter小提示




一、JMeter简介


1.定义

JMeter是Apache组织开发的基于Java的压力测试工具。用于对软件做压力测试,它最初被设计用于Web应用测试,但后来扩展到其他测试领域。

    1)它可以用于测试静态和动态资源,例如静态文件、Java 小服务程序、CGI 脚本、Java 对象、DB、FTP 服务器, 等等。

    2)JMeter 可以用于对服务器、网络或对象模拟巨大的负载,来自不同压力类别下测试它们的强度和分析整体性能。

    3)JMeter能够对应用程序做功能/回归测试,通过创建带有断言的脚本来验证程序是否返回了预期结果。为了最大限度的灵活性,JMeter允许使用正则表达式创建断言。

    4)JMeter支持的协议有:Web(Http、Https)、SOAP、FTPd、JDBC、邮件、MongoDB、TCP、原生命令或Shell脚本

2.JMeter的优势

    1)可对任何DB进行压力测试(通过JDBC)

    2)纯Java,可移植性强

    3)轻量组件支持包(预编译的JAR使用javax.swing.*)

    4)多线程(多个线程并发或通过单独的线程组对不同功能同时操作)

    5)计时精确

    6)缓存和离线分析,回放测试结果

    7)完全开源,可对JMeter进行二次开发,增加业务对应所需的插件

3.JMeter不足

    1)录制功能操作不方便。需要第三方工具Badboy或使用Browser代理录制

    2)入门困难,同时网上学习资源较少

    3)报表类型少,场景设计比LR复杂

    4)不支持进程模式

    5)大并发时的结果不准确。




二、JMeter功能介绍

111.png

1.测试计划

    启动JMeter后,默认打开了一个测试计划,一个完整的测试计划划包含一个或多个线程组、逻辑控制、取样发生控制、监听器、定时器、断言和配置元件。

2.线程

    相当于LR中的VUser,每个JMeter测试计划的第一步就是添加线程组。在线程组里设置并发用户量、并发时间或并发次数、线程的启动频率。

    JMeter的线程组有三种类型:

        setup thread group: setup ,进行测试前的准备初始化工作,即init

        teardown thread group:teardown,测试结束后的垃圾回收等清理工作,即end

        thread group:最常用的线程组,相当于Action .一个线程相当于一个LR中的Vuser,这些线程在脚本运行过程中无法改变。

3.测试片段(Test Fragment)

    测试片段元素像是控制器上的一种特殊的线程组,在测试树上与线程组同级。但它不被执行,除非引用 。

4.取样器Sampler

    性能测试中向服务器发送请求并等待响应时间的最小单元,每个取样器有不同的属性可以编辑。

5.逻辑控制器

    可自定义JMeter发送请求的行为逻辑 ,与Sampler结合使用可以模拟复杂的请求序列。常用的逻辑控制器有:IF Controller、While Controller、Runtime Controller、事务控制器、随     机控制器、交替控制器、吞吐量控制器、模块控制器等。

6.监听器

    对JMeter测试结果进行收集处理并进行可视化展现出的一系列元件,包括发送的请求数据、返回的结果数据、响应时间的统计、吞吐量、错误率、返回结果状态等。常见的监听器有:图       形结果、查看结果树、用表格查看结果、聚合报告等。

7.配置元件

    维护Sampler需要的配置信息,并根据实际需要修改请求内容 。一般配置元件放在请求开始前。

8.定时器

    即思考时间。一来为了真实地模拟用户并发行为,二来控制每个线程间的请求间隔时间以减少服务器压力。

9.断言

    即检查点。压力测试前提是功能正确。常用的断言有:响应断言、XML断言、HTML断言、XPath断言。

10.前置处理器

    用来修改请求的设置。eg.Http URL重写修复符可实现URL重写,当RUL中有sessionID一类的session信息时,可通过该处理器填充发出请求的实际sessionID

11.后置处理器

    即关联。用于对Sampler发出请求后得到的服务器响应数据进行处理。一般用于提取响应中的特定数据,如用后置处理器中的正则表达式提取器对服务器返回的特定数据进行关联操作。



本文转自 honzhang 51CTO博客,原文链接:http://blog.51cto.com/hongz/2065065

相关实践学习
通过性能测试PTS对云服务器ECS进行规格选择与性能压测
本文为您介绍如何利用性能测试PTS对云服务器ECS进行规格选择与性能压测。
相关文章
|
24天前
|
Java 测试技术 数据安全/隐私保护
软件测试中的自动化策略与工具应用
在软件开发的快速迭代中,自动化测试以其高效、稳定的特点成为了质量保证的重要手段。本文将深入探讨自动化测试的核心概念、常见工具的应用,以及如何设计有效的自动化测试策略,旨在为读者提供一套完整的自动化测试解决方案,帮助团队提升测试效率和软件质量。
|
17天前
|
Web App开发 IDE 测试技术
Selenium:强大的 Web 自动化测试工具
Selenium 是一款强大的 Web 自动化测试工具,包括 Selenium IDE、WebDriver 和 Grid 三大组件,支持多种编程语言和跨平台操作。它能有效提高测试效率,解决跨浏览器兼容性问题,进行性能测试和数据驱动测试,尽管存在学习曲线较陡、不稳定等缺点,但其优势明显,是自动化测试领域的首选工具。
113 17
Selenium:强大的 Web 自动化测试工具
|
13天前
|
人工智能 自然语言处理 前端开发
CodeArena:在线 LLM 编程竞技场!用于测试不同开源 LLM 的编程能力,实时更新排行榜
CodeArena 是一个在线平台,用于测试和比较不同大型语言模型(LLM)的编程能力。通过实时显示多个 LLM 的代码生成过程和结果,帮助开发者选择适合的 LLM,并推动 LLM 技术的发展。
44 7
CodeArena:在线 LLM 编程竞技场!用于测试不同开源 LLM 的编程能力,实时更新排行榜
|
27天前
|
机器学习/深度学习 人工智能 算法
BALROG:基准测试工具,用于评估 LLMs 和 VLMs 在复杂动态环境中的推理能力
BALROG 是一款用于评估大型语言模型(LLMs)和视觉语言模型(VLMs)在复杂动态环境中推理能力的基准测试工具。它通过一系列挑战性的游戏环境,如 NetHack,测试模型的规划、空间推理和探索能力。BALROG 提供了一个开放且细粒度的评估框架,推动了自主代理研究的进展。
38 3
BALROG:基准测试工具,用于评估 LLMs 和 VLMs 在复杂动态环境中的推理能力
|
1月前
|
监控 测试技术 开发工具
移动端性能测试工具
移动端性能测试工具
49 2
|
1月前
|
安全 前端开发 测试技术
如何选择合适的自动化安全测试工具
选择合适的自动化安全测试工具需考虑多个因素,包括项目需求、测试目标、系统类型和技术栈,工具的功能特性、市场评价、成本和许可,以及集成性、误报率、社区支持、易用性和安全性。综合评估这些因素,可确保所选工具满足项目需求和团队能力。
|
1月前
|
安全 网络协议 关系型数据库
最好用的17个渗透测试工具
渗透测试是安全人员为防止恶意黑客利用系统漏洞而进行的操作。本文介绍了17款业内常用的渗透测试工具,涵盖网络发现、无线评估、Web应用测试、SQL注入等多个领域,包括Nmap、Aircrack-ng、Burp Suite、OWASP ZAP等,既有免费开源工具,也有付费专业软件,适用于不同需求的安全专家。
184 2
|
1月前
|
监控 网络协议 Java
一些适合性能测试脚本编写和维护的工具
一些适合性能测试脚本编写和维护的工具
|
1月前
|
测试技术 持续交付 Apache
Python性能测试新风尚:JMeter遇上Locust,性能分析不再难🧐
Python性能测试新风尚:JMeter遇上Locust,性能分析不再难🧐
77 3
|
1月前
|
缓存 测试技术 Apache
告别卡顿!Python性能测试实战教程,JMeter&Locust带你秒懂性能优化💡
告别卡顿!Python性能测试实战教程,JMeter&Locust带你秒懂性能优化💡
58 1