博文目录
一、Jmeter
1、Jmeter介绍
JMeter 是 Apache开发的压力测试开源软件,是100%纯Java的应用程序,同时又是一款接口测试工具。设计用于模拟负载测试功能行为和衡量性能,最初是为测试Web应用程序而设计的,但后来扩展到了其他测试功能。
Apache JMeter 可用于测试静态和动态资源、Web动态应用程序的性能,能够对于应用程序做功能/回归测试,通过创建带有断言的脚本来验证程序返回了期望的结果。
它可以用来模拟服务器、服务器组、网络或对象上的重负载,以在不同压力类别下测试其强度或分析不同负载类型下的总体性能。
博主本文着重从 Jmeter 测试后端数据库 MySQL 的切入点入手,展示 Jmeter 性能测试的部分基本操作。
2、JMeter特性
- 能够加载和性能测试多种不同的应用程序/服务器/协议类型:
- Web-HTTP、HTTPS(Java、NodeJS、PHP、ASP.NET等)
- SOAP/REST Web服务
- 文件传输协议
- 通过JDBC的数据库
- 基于JMS的消息中间件(MOM)
- 邮件-SMTP、POP3和IMAP
- 本机命令或shell脚本
- 传输控制协议
- Java对象
- 允许快速测试计划录制(从浏览器或本机应用程序)、生成和调试
- CLI模式(Non GUI模式/无头模式)从任何Java兼容操作系统(Linux、Windows、Mac OSX等)负载测试
- 一个完整的准备好呈现动态HTML报表
- 通过从最流行的响应格式中提取数据的能力,HTML,JSON,XML或任何文本格式
- 完全的便携性和100%纯Java
- 缓存和离线分析/回放测试结果
3、Jmeter安装
-
JDK
- 前往 oracle 官网下载 建议最好是 JDK1.8 以上版本
- 新建一个系统变量
JAVA_HOME
,变量值为 JDK 所在路径,如D:\Program Files (x86)\Java\jdk1.8.0_191
- 需要编辑系统变量path,增加
%JAVA_HOME%\bin
-
Jmeter 安装与启动
-
前往 Jmeter 官网下载压缩包,无需安装直接解压到某个路径,如
D:\Program Files (x86)\Apache\apache-jmeter-5.0
,目录介绍如下图 -
在 Jmeter 路径
D:\Program Files (x86)\Apache\apache-jmeter-5.0\bin
下输入jmeter.bat
,即可启动 Jmeter (GUI) 图形化界面 -
Jmeter 也讲了,如果要进行测试,应该使用 Non GUI 模式
指令如下
jmeter -n -t [jmx file] -l [results file] -e -o [Path to web report folder]
-
4、Jmeter 测试 JDBC 的场景
Jmeter 是 100% Java 应用程序,要用 Jmeter 发送大量的 SQL 数据查询给 MySQL 数据库,以此来测试其性能;就必须要用到 Java 连接 MySQL 的驱动。
二、服务器端准备数据库数据
1、MySQL命令行
进入数据库服务器端(VMWare虚拟机)
cd 到 XAMPP 的 mysql 的 bin 路径下
或通过 XAMPP Control Panel 的 Shell
2、数据库操作准备测试数据
首先登录 mysql 的 root 账户
mysql --user root --password -- 或 mysql -u root -p
笔者密码设置为空故直接回车,之后进入的却是 MariaDB 命令行,但是表慌 😉
这种情况的原因是 MySQL 被 Oracle 收购后,MySQL 的作者 Michael Widenius 为了解决社区版被闭源的风险,开发了 MySQL 分支,随后用他小女儿 Maria 的名字起名为 MariaDB,而 MySQL 本身就是用他另一个女儿 My 命名的,这位大爷就是厉害啊,orz,哈哈。MariaDB 与 MySQL的有高度的兼容性,毕竟是姐姐妹妹嘛。
言归正传,然后命令行 SQL 操作数据库,准备待测试数据。当然可以通过创建带有 while 循环的存储过程 PROCEDURE,或其他方法来批量插入大量的随机测试数据;但是本文重点不在此,故只是插入少量数据;另外如果要大批量插入,建议建表时更换数据库引擎为 InnoDB
-- 查看现有数据库
SHOW DATABASES;
-- 创建一个database,db_user
CREATE DATABASE db_user CHARACTER SET utf8 COLLATE utf8_general_ci;
-- 切换至db_user
USE db_user;
-- 创建一张table,tb_user
CREATE TABLE tb_user(username varchar(20),password varchar(30));
-- 往tb_user中插入数据
INSERT INTO tb_user (username,password) VALUES ('Tom',md5('123456')),('Jerry',md5('67890'));
-- 查询验证操作
SELECT * FROM tb_user;
SQL操作及结果如下:
查询结果
三、Jmeter 测试 JDBC 步骤
1、测试计划配置
测试计划中 “添加 jar 包到 Classpath“,选择下好的 mysql-connector-java-5.1.28.jar
2、线程组配置
根据测试需求,配置线程组的线程数、Ramp-up时间、循环次数等
3、线程组添加配置元件: JDBC Connection Configuration
(1) Jmeter 操作
添加配置元件 JDBC Connection Configuration
准备好配置的值:
-
Variable Name for created pool
myjdbc
-
Database URL
jdbc:mysql://mysql数据库服务器IP地址:mysql端口号/要连接的database名称
如:
jdbc:mysql://192.168.8.134:3306/db_user
-
JDBC Driver class
com.mysql.jdbc.Driver
-
Username & Password
root 123456
填入以上配置参数,其他参数选择默认
(2) MySQL 操作
JDBC Connection Configuration
中 Database URL
使用了ip地址来访问某个MySQL数据库服务器;
而要通过ip地址实现访问MySQL,就必须要先在数据库服务器上开通允许远程设备连接的权限。
-- 切换到mysql数据库
USE mysql;
-- 授予全部权限,'root'@'%'为所有主机的root账号,‘123456’为远程连接到mysql的密码
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123456';
-- 刷新权限后生效
FLUSH PRIVILEGES;
-- 查询设置成功
SELECT host,user,password FROM user;
在数据库服务器端,SQL操作结果如下
4、线程组添加取样器:JDBC Request
添加取样器 JDBC Request
配置 JDBC 请求:
包括填入之前 JDBC Connection Configuration 里设置过的变量名,选定测试SQL语句的类型,书写性能测试要围绕进行的SQL语句。
5、添加监听器
添加察看结果树、汇总报告、图形结果、响应时间图等等监听器;在监听器中,可以看到这个查询或其他SQL语句所耗费的时间、效率、吞吐量、QPS等等一系列性能测试指标。
结果如下
察看结果树可看到响应的具体数据
用其他监听器查看性能指标
设置集合点、检查点、添加断言、断言结果等等
四、本文性能测试总结
1、首先MySQL数据库服务器端准备好了待测数据。
2、Jmeter中创建测试计划,并且添加 mysql-connector-java-5.1.28.jar的jar包。
3、创建线程组,设置线程数、Ramp-up、循环次数等
4、线程组添加配置元件 JDBC Connection Configuration,设置变量名,要连接的数据库URL( jdbc:mysql://192.168.8.129:3306/db_1 ),驱动包名 com.mysql.jdbc.Driver,远程连接的账号密码。
5、在数据库服务器端授权远程设备可以通过ip连接MySQL数据库
6、线程组中添加取样器 JDBC Request,设置JDBC连接配置里的变量名,选择要测的SQL查询语句类型,以及SQL语句。
7、添加察看结果树、汇总报告、图形结果等之类的监听器
8、Jmeter运行并查看性能测试结果
五、博主原创手动码字,喜欢就点赞收藏哦
博主唯一首发CSDN,写这篇博客一来为了提醒自己的知识记忆,二来记录过程,三来践行交流分享精神;-)