Jmeter脚本录制和压测

1. 什么是脚本录制

在进行测试的时候,可能有好多脚本或者界面需要操作测试,并且有些测试链接需要重复多线程高并发进行测试,我们一般会针对这一些操作,进行一个脚本录制,录制好之后,之后测试就可以在这个基础上进行测试。

2. Jemeter脚本录制方式

web端:BadBoy脚本录制

app端:使用Jmeter自带的代理服务器进行脚本录制



3. Android手机端脚本录制

前提:电脑和手机在同一网络段上


1:添加http代理服务器


2:在线程中添加录制控制器



3:在http代理服务器中指定录制脚本的路径,默认端口8888


4:查看本地的ip(wifi热点)


5:设置移动端代理,IP和端口号



6:启动

点击”ok”

7:打开手机app,抓取接口


8:点击”停止”按钮,结束录制


操作文档


4.web端脚本录制

4.1. 安装badboy脚本软件

傻瓜式安装即可


4.2. 打开badboy软件


4.3. badboy脚本录制

点击录制按钮进行脚本录制,完成打开搜狗搜索,搜索测试岗位薪资操作,然后停止,回放,(回放的时候,会因为编码原因导致乱码,需要手动调乱码问题)


4.4. 添加验证点

验证点的作用就是验证脚本是否按照我们测试的思路执行,判断脚本执行过程中是否存现问题


4.5. badboy参数化

所谓参数化,是指请求的某个参数提前设定多个值,在具体请求的时候,去获取提前设定的值,不同的业务场景设置的参数不一致。


4.6. 导出Jmeter脚本


4.7. 在Jmeter中导入badboy生成的脚本,验证测试

4.8. badboy并发测试

选择tools run background


4.9. badboy测试报告

在badboy-->view--->report下可以看到测试报告


5. Jmeter扩展插件-显示内存效果图

Jmeter本身是不能够展示内存,cpu和吞吐量的,但是可以通过添加插件的方式来对jmeter添加这些功能


https://www.cnblogs.com/imyalost/p/7751981.html

JMeter之ServerAgent监控资源





5.1.  对linux服务器的服务进行压测

时,服务器的运行情况可以通过添加插件来观察,而不用使用top命令实时的去看

  1、资源准备

  2、环境准备

  3、资源监控

1、资源准备

  可通过该网址下载jmeter所有插件http://jmeter-plugins.org/downloads/all/

  万能的网盘:

  本次所需插件:

  JMeterPlugins-Extras.jar

  JMeterPlugins-Standard.jar

  ServerAgent-2.2.1

  将JMeterPlugins-Extras.jar和JMeterPlugins-Standard.jar放到apache-jmeter-3.0\lib\ext目录下

  将ServerAgent-2.2.1放到linux服务器opt目录下

  2、环境准备

  ServerAgent服务端口号默认为4444,需要设置防火墙对此端口不拦截:

开放Linux的对外访问的端口4444

/sbin/iptables -I INPUT -p tcp --dport 4444 -j ACCEPT

/etc/rc.d/init.d/iptables save ---将修改永久保存到防火墙中

  (vi /etc/sysconfig/iptables,在端口22下面添加 iptables -I INPUT -p tcp --dport 4444 -j ACCEPT   //允许4444端口访问)

然后在服务器中启动监控服务:

使用以下命令可以改变默认的4444端口

  java -jar ./CMDRunner.jar --tool PerfMonAgent --udp-port 7777 --tcp-port 7777

  同样的,7777端口也要设置防火墙规则以及使用telnet本地测试下是否可以访问

操作文档


5.2.  windows本机进行监听





先在服务器上开启server的监听



开始演示效果

jp@gc - Bytes Throughput Over Time:不同时间吞吐量(字节Bytes)展示(图表)

聚合报告里,Throughput是按请求个数来展示的,比如说1.9/sec,就是每s发送1.9个请求;而这里的展示是按字节Bytes来展示的图表,表示每秒发送多少字节

jp@gc - Hits per Second:每秒点击量,点击量在性能测试-常见的性能指标(一)的博文中已经详细介绍,指的是每秒web服务器接收到的请求数

jp@gc - PerfMon Metrics Collector:服务器性能监测控件,包括CPU,Memory,Network,I/O等等(此功能用到在需监听的服务器上启动startAgent)

根据需要选择CPU,Memory,Network I/O等



6. Jmeter数据库压力测试

6.1.  先配置jdbc(数据库连接)驱动

1、启动jmeter,打开界面工具,添加一个线程组,添加驱动

2、添加一个JDBC Connection Configuration,连接池配置文件。右键线程组【添加】--【配置元件】--【JDBC Connection Configuration】





Variable Name:连接池名称。JDBC Request会通过此名称来获取连接池的配置,名称可以随意填写,但是最好具体实际的业务意义,方便理解和记忆。


其他的可以默认,可以根据实际情况来调节优化性能。


Database URL:数据链接url,格式:jdbc:mysql://localhost:3306/host


注释:数据库的ip地址+端口/数据库名(查询数据库端口号show global variables like 'port')

jdbc:mysql://127.0.0.1:3306/mydb2?serverTimezone=UTC& allowMultiQueries=true


JDBC Driver Class:驱动器名称。固定:com.mysql.jdbc.Driver


Username:用户名


Passowrd:密码

添加一个JDBC Request。


3、右键线程组【添加】-【Sampler】-【JDBC Request】


Select Statement:查询语句

只能执行查询语句select,执行第一条sql语句,而且第一条必须是select语句,否则报错

Updata Statement:更新语句

支持测试非select语句,并且支持测试多条,若其中夹杂select语句,自动忽略,若第一条语句为select语句,报错

Callable Statement:所有语句

只要语法正确,任何语句,再多的条数都能支持

Prepared Select Statement:预编译查询语句。(长时间执行效率更高,支持占位符)

Prepared Update Statement:预编译更新语句。(同上)

Commit (立即提交)Rollback(回滚)


Parameter  values:参数值。参数化sql语句中的值


Paramter  types:参数类型。数据库的参数你可以去查看一下。这里是varchar类型。


Variable names:变量名字,也就是将筛选出来的值放在变量里面。例如这三列数据分为放在变量:A,B,C中(实际操作中命名一定要有实际意义)。


Result variable name:存储变量名。将整个结果存储在变量中。取名:rs


Query timeouts:超时时间。

你可能感兴趣的:(Jmeter脚本录制和压测)