[TOC]

0x00 前言简述

1.JMeter 介绍

Q: 什么是Apache JMeter ?

JMeter 是一款开源纯 Java 应用程序, 旨在测量性能和负载测试应用程序, 目前由 Apache 软件基金会提供支持。

Q: 我能用 Apache JMeter 做什么?

Apache JMeter 可以测量性能并对静态和动态 Web 应用程序进行负载测试, 它可用于模拟服务器、服务器组、 网络或对象来测试其强度或分析不同负载类型下的整体性能。

Apache JMeter 功能包括:
1) 能够加载和性能测试许多不同的应用程序/服务器/协议类型:

* Web - HTTP、HTTPS(Java、NodeJS、PHP、ASP.NET,...)
* SOAP / REST Web 服务
* FTP
* 通过 JDBC 的数据库
* LDAP
* 通过 JMS 的面向消息的中间件 (MOM)
* 邮件 - SMTP(S)、POP3(S) 和 IMAP(S)
* 本机命令或 shell 脚本
* TCP
* Java 对象

2) 功能齐全的测试 IDE,允许快速 记录测试计划(从浏览器或本机应用程序)、构建和调试 。
3) CLI 模式(命令行模式(以前​​称为非 GUI)/无头模式) 可从任何 Java 兼容操作系统(Linux、Windows、Mac OSX 等)进行负载测试
4) 完整且可随时呈现的动态 HTML 报告, 实时数据采集进入第三方数据库,如 InfluxDB 或 Graphite
5) 通过从最流行的响应格式、 HTML 、 JSON 、 XML 或 任何文本格式
6) 完全的可移植性和 100% Java 纯度 。
7) 完整 的多线程 框架允许多线程并发采样,并且 通过不同的线程组同时采样不同的功能。
8) 缓存和离线分析/重放测试结果。
9) 高度可扩展的核心:

* 可插拔采样器允许无限的测试能力。
* 可编写脚本的采样器 等 JSR223 兼容的语言 Groovy 和 BeanShell
* 选择几个负载统计信息 可插入计时器 。
* 数据分析和 可视化插件 允许很好的可扩展性 以及个性化。
* 函数可用于为测试提供动态输入或提供数据操作。
* 轻松实现持续集成 rd Maven、Gradle 和 Jenkins 的


Q: JMeter和浏览器间的区别?

JMeter 不是浏览器它在协议级别工作。 就 Web 服务和远程服务而言,JMeter 看起来像一个浏览器(或者更确切地说,是多个浏览器); 但是 JMeter 并不执行浏览器支持的所有操作。 特别是 JMeter 不执行 HTML 页面中的 Javascript, 它也不像浏览器那样呈现HTML页面(可以将响应查看为HTML 等,但时间不包含在任何示例中,并且一次只显示一个线程中的一个示例)。

n.官网参考

官网地址: https://jmeter.apache.org/
项目地址: https://github.com/apache/jmeter
下载地址: https://jmeter.apache.org/download_jmeter.cgi
官方文档: https://jmeter.apache.org/usermanual/get-started.html


0x01 安装配置

1.环境要求

  • Java Interpreter (解释器):Apache JMeter需要完全兼容的Java 8运行时环境才能执行, 带有keytool实用程序的JDK更适合记录HTTPS网站。

  • Java Compiler (可选):由于发行版包含预编译的Java二进制归档文件,因此不需要Java编译器。

  • jar Plugin (可选):JMeter中不包括一些JAR, 如果需要应下载这些文件并将其放置在lib目录中。

温馨提示: 目录名称中的空格可能会导致问题。


2.下载安装

描述: 当前【2022年5月31日 10:40:57】Apache JMeter 官网版本为 5.4.3 (Requires Java 8+),提供两种格式下载Binaries、Source

Windows

操作部署
步骤 01.从Apache官网下载 Apache JMeter (https://dlcdn.apache.org//jmeter/binaries/apache-jmeter-5.4.3.zip)

步骤 02.安装 jdk 环境此处我的安装环境为 jdk-8u251-windows-x64.exe, 安装路径为D:\Study\Java

1
2
3
4
5
6
7
8
9
10
11
# CMD
setx JAVA_HOME "D:\Study\Java\jdk1.8.0_251" /M
setx JRE_HOME "D:\Study\Java\jdk1.8.0_251\jre" /M
setx CLASSPSTH ".;%JAVA_HOME%\lib\dt.jar;%JAVA_HOME%\lib\tools.jar;" /M
setx PATH "%PATH%;%JAVA_HOME%\bin\;" /M

# 版本查看
> java -version
java version "1.8.0_251"
Java(TM) SE Runtime Environment (build 1.8.0_251-b08)
Java HotSpot(TM) 64-Bit Server VM (build 25.251-b08, mixed mode)

步骤 03.解压 apache-jmeter-5.4.3.zip 并访问 apache-jmeter-5.4.3\bin 目录 , 执行jmeter.bat (Windows)文件, 如果是linux则执行jmeter.sh文件,如果是Mac请执行jmeter(Unix)文件。
此处执行: D:\Tools\apache-jmeter-5.4.3\bin\jmeter.bat
温馨提示: 对于 Windows 环境, 我们还有一些其他脚本,我们可以拖放一个 JMX 文件到其中:

  • jmeterw.cmd - 在不使用windows shell控制台的情况下运行JMeter(默认情况下为GUI模式)
  • jmeter-n.cmd - 将文件作为非 GUI 测试运行
  • jmeter-n-r.cmd - 将文件作为非 GUI 远程(客户端-服务器)测试运行
  • jmeter-t.cmd - 加载文件准备运行它作为一个 GUI 测试
  • jmeter-server.bat - 在服务器模式下启动JMeter

步骤 05.运行后将会显示如下界面。

WeiyiGeek.apache-jmeter-5.4.3

WeiyiGeek.apache-jmeter-5.4.3


Docker

操作部署

1
2
3
4
5
wget -c https://dlcdn.apache.org//jmeter/binaries/apache-jmeter-5.4.3.tgz
mkdir -vp ./build && tar -zxf ./apache-jmeter-5.4.3.tgz -C ./build

~/jmeter$ ls build/apache-jmeter-5.4.3/
bin docs extras lib LICENSE licenses NOTICE printable_docs README.md


3.配置参数

描述: 有几个环境变量可用于定制JMeter的JVM设置, 设置这些的一种简单方法是创建一个名为setenv.bat文件在bin目录中。

1
2
3
# bin\setenv.bat
# REM: 它将会被 bin\jmeter.bat 调用并覆盖其默认值。
set JVM_ARGS=-Xms1024m -Xmx1024m -Dpropname=value

可用参数:

  • DDRAW - 用于直接绘制JVM选择, 例如-Dsun.java2d.ddscale=true, 默认为空。
  • GC_ALGO - JVM 垃圾收集器选项, 默认-XX:+UseG1GC -XX:MaxGCPauseMillis=250 -XX:G1ReservePercent=20
  • HEAP - 启动 JMeter 时使用的 JVM 内存设置。 默认为-Xms1g -Xmx1g -XX:MaxMetaspaceSize=256m
  • JMETER_BIN - JMeter bin 目录( 必须以 \ )
  • JMETER_COMPLETE_ARGS - 如果设置指示 JVM_ARGS 和 JMETER_OPTS 。 其他 HEAP 和 GC_ALGO 选项将被忽略。
  • JMETER_HOME - jmeter 安装目录, 及jmeter.bat存放的目录
  • JMETER_LANGUAGE - Jmeter 运行时选项来指定使用的语言, 默认值为-Duser.language="en" -Duser.region="EN"
  • JM_LAUNCH - java 可执行文件的名称,如 java.exe (默认)或 javaw.exe
  • JVM_ARGS - 启动 JMeter 时要使用的 Java 选项, 他会将其添加到java执行的命令行中。

温馨提示: JVM 参数可用于覆盖JMeter.bat脚本中的JVM设置,它会在启动JMeter时设置。

https://jmeter.apache.org/usermanual/get-started.html#running