文档章节

五.jmeter代码学习(2)

木子木
 木子木
发布于 2014/03/24 15:58
字数 1271
阅读 1552
收藏 13

使用JMeter做压力测试

1.下载Jmeter

地址:http://jmeter.apache.org/download_jmeter.cgi 

2.启动jmeter

运行bin/jmeter.bat

3.添加线程组

TestPlan节点上右键,Add-->Threads(Users)-->Thread Group

Number of Threads (Users):要模拟的并发用户量。
Ramp Up Period (in seconds):在多长时间内均匀启动所有的线程。比如Number of Threads设为10Ramp Up Period设为1,则jmeter每隔0.1秒启动1个线程。
Loop Count:单用户任务重复执行的次数。可以设为Forever,这样jmeter就不会自动停止,需要强制终止。
还可以设置Scheduler Configuration。这里有两组设置:指定StartTimeEnd Timejmeter在特定的时间区段内执行工作;Startup Delay表示从当前时刻开始延迟多长时间开始运行,Duration设定运行时长。

4.用jmetr向服务器发送Java Request

当然传统的方法是让jmeter向服务器发送Http RequestFTP Request,但这里不作展示。

假如我们要模拟多用户并发向Zookeeper Cluster发送查询znode的请求,首先要写1个程序来指定单用户的请求行为。

新建一个Java Project,导入jmeter/lib/ext下的两个jar包:ApacheJMeter_core.jarApacheJMeter_java.jar

?

package test;
 
import org.apache.jmeter.config.Arguments;
import org.apache.jmeter.protocol.java.sampler.AbstractJavaSamplerClient;
import org.apache.jmeter.protocol.java.sampler.JavaSamplerContext;
import org.apache.jmeter.samplers.SampleResult;
import org.apache.zookeeper.ZooKeeper;
 
public class Create extends AbstractJavaSamplerClient{
     private String nodePath= null ;
     private String timeout_str= null ;
     private SampleResult results;
     
      //设置传入的参数,可以设置多个,已设置的参数会显示到Jmeter的参数列表中
     public Arguments getDefaultParameters() {
         Arguments params = new Arguments();
         params.addArgument( "nodePath" , "" );
         params.addArgument( "timeout_str" , "5000" );
         return params;
     }
     
     //初始化方法,实际运行时每个线程仅执行一次,在测试方法运行前执行
     public void setupTest(JavaSamplerContext arg0) {
         results = new SampleResult();
         nodePath = arg0.getParameter( "nodePath" );   //获取在Jmeter中设置的参数值
         if (nodePath != null && nodePath.length() > 0 ) {
             results.setSamplerData(nodePath);
         }
         timeout_str=arg0.getParameter( "timeout_str" );
         if (timeout_str != null && timeout_str.length() > 0 ) {
             results.setSamplerData(timeout_str);
         }
     }
 
      //测试执行的循环体,根据线程数和循环次数的不同可执行多次
     @Override
     public SampleResult runTest(JavaSamplerContext arg0) {
         int timeout=Integer.parseInt(timeout_str);
         boolean success= true ;
         results.sampleStart();      //事务的起点
         try {
             ZooKeeper zkp= new ZooKeeper( "localhost:2181" ,timeout, null );
             zkp.getData(nodePath, false , null );
             zkp.close();
         } catch (Exception e) {
             success= false ;
         } finally {
             results.sampleEnd();    //事务的终点
             results.setSuccessful(success);     //设置本次事务成功或失败
         }
         return results;
     }
     
     //结束方法,实际运行时每个线程仅执行一次,在测试方法运行结束后执行
     public void teardownTest(JavaSamplerContext arg0) {
     }
}

project导出为jar包,放到jmeter/lib/ext下,重启jmeter

Thread Group上是右击,Add-->Sampler-->Java Request

设置nodePathtimeout的值。

5.添加Listener

TestPlan上右击,Add-->Listener-->Aggregate ReportJmeter生成的报告有多种,这里以Aggregate Report为例。

可以指定将report保存到某个文件,如上图中所示保存到report.csv,在非GUI模式下运行Jmeter这是非常必要的。

 

可以在bin/jmeter.properties中设置report文件的默认格式,你可能要经常要更改这两项配置:jmeter.save.saveservice.output_format=csv #默认有文件格式为jtl jmeter.save.saveservice.default_delimiter=\t #默认使用","作为域之间的分隔符

 

点击Configure可以自己定义report中你所关心的数据项。

比如我只关心每个请求是否成功,以及每个请求所用的时间,所以只勾选了两项。

6.为Jmeter安装PerfMon插件

PerfMon用来监控ServerCPUI/OMemory等情况。

1. 插件下载地址:http://code.google.com/p/jmeter-plugins/wiki/PerfMon 

2. 把JMeterPlugins.jar放到jmeter客户端的jmeter/lib/ext下。

3. 启动jmeter,添加Listener时你就看到PerfMon Metrics Collectors了。

4. 另外还需要把下载下来的PerfMon解压后放到所有的被测试的服务器上,并运JMeterPlugins/serverAgent/startAgent.sh,默认工作在4444端口。

5. 使用PerfMon截图:

再次提醒一下,在非GUI模式下运行Jmeter时指定把result保存到一个文件是非常必要的。

7.非GUI模式下运行Jmeter

具体方法是:先在GUI模式下创建TestPlan,保存为jmx文件。命令行启动jmeter./ApacheJMeter -n -t testplan.jmx (选项-n表示non-GUI-t指定TestPlan文件)。运行结束后Aggregate ReportPerfMon Metrics Collector就会保存在你指定的文件中。把保存PerfMon Metrics Collector的文件拖到Jmerter GUI中就可以看到CUP等使用状况拆线图了。

8.远程启动jmeter

应用进场景:用一台机器(称为JMeter客户端)上的jmeter同时启动另外几台机器(称为JMeter远程服务器)上的jmeter

1. 保证jmeter客户端和jmeter远程服务器采用相同版本的jmeterJVM

2. jmeter客户端和jmeter远程服务器最好在同一个网段内。

3. 在jmeter远程服务器上运行JMETER_HOME/bin/jmeter-server (UNIX)或者JMETER_HOME/bin/jmeter-server.bat(Windows)脚本 。

4. 在jmeter客户端上修改/bin/jmeter.properties文件,找到属性"remote_hosts",使用JMeter远程服务器的IP地址作为其属性值。可以添加多个服务器的IP地址,以逗号作为分隔。 
例如:
#remote_hosts=127.0.0.1
remote_hosts=9.115.210.2:1099,9.115.210.3:1099,9.115.210.4:1099
# RMI port to be used by the server (must start rmiregistry with same port)
server_port=1099

5. 在jmeter客户端上启动jmeter:
./jmeter -n -t plan.jmx -r #选项-r表示远程启动(remote)
jmeter客户端会自动向jmeter远程服务器上分发测试计划。

本文转载自:http://www.cnblogs.com/zhangchaoyang/articles/2530731.html

木子木

木子木

粉丝 5
博文 37
码字总数 7425
作品 0
朝阳
私信 提问
加载中

评论(1)

mahengyang
mahengyang
很不错
【Jmeter】Jmeter使用AbstractJavaSamplerClient编写自定义流程测试

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/kisscatforever/article/details/83416193 一、前言 在上一篇博客中,小编向大家简单介绍了jmeter 的GUI界面的...

AresCarry-王雷
2018/10/26
0
0
性能测试工具操作数据库(五)-Jmeter与MongoDB

JMeter测试MongoDB性能有两种方式,一种是利用JMeter直接进行测试MongoDB,还有一种是写Java代码方式测试MongoDB性能。 第一种方法 1.编写Java代码,内容如下: 2.生成jar包,放在Jmeter_HO...

smooth00
2017/03/28
0
0
linux环境下使用jmeter做性能测试

只需一行命令:sh jmeter.sh -n -t http.jmx -l result_*.jtl 步骤: 一 安装jmeter 1 把你笔记本的jmeter添加到压缩包 jmeter.zip 2 上传jmeter.zip到linux服务器:我用rz方式上传到了/opt/...

孟飞阳
2018/05/24
401
0
JMeter学习-002-JMeter环境配置

本节主要介绍 JMeter 本地环境配置(JMeter 版本为 apache-jmeter-2.12),详细配置如下: 一、JDK配置 默认用户本地已经安装且配置好 JDK。若未配置,进行 JDK 环境安装配置。 二、下载JMe...

拎壶冲冲冲
2018/05/29
0
0
Jmeter之Bean shell使用

 上一篇简单介绍了下Jmeter中的Bean shell,本文是对上文的一个补充,主要总结下常用的几种场景和方法,相信这些基本可以涵盖大部分的需求。本节内容如下: 一、操作变量 二、操作属性 三、...

覃光林
2018/05/10
129
0

没有更多内容

加载失败,请刷新页面

加载更多

定期批量改密,实现高效运维,保障口令安全

随着企业IT资产规模的不断增大,各类主机、应用系统的管理也变得愈加困难。 对于系统管理员来说,保证操作系统的密码安全是其重要工作,在需要维护众多的主机时,其面临的困境将是: 1、难以...

堡垒啊
20分钟前
2
0
怎样在磁盘上查找MySQL表的大小?这里有答案

导读 我想知道 MySQL 表在磁盘上占用多少空间,但看起来很琐碎。不应该在 INFORMATION_SCHEMA.TABLES 中提供这些信息吗?没那么简单! 我想知道 MySQL 表在磁盘上占用多少空间,但看起来很琐碎...

问题终结者
46分钟前
6
0
jQuery load() 方法实现加载远程数据

jQuery load() 方法是简单但强大的 AJAX 方法。load() 方法从服务器加载数据,并把返回的数据放入被选元素中。 语法: $(selector).load(URL,data,callback);必需的 URL 参数规定您希望加载的...

前端老手
48分钟前
5
0
Spring Boot缓存实战 Redis 设置有效时间和自动刷新缓存-2

问题 上一篇Spring Boot Cache + redis 设置有效时间和自动刷新缓存,时间支持在配置文件中配置,说了一种时间方式,直接扩展注解的Value值,如: @Override@Cacheable(value = "people#${s...

xiaolyuh
56分钟前
10
0
怎样在磁盘上查找MySQL表的大小?这里有答案

我想知道 MySQL 表在磁盘上占用多少空间,但看起来很琐碎。不应该在 INFORMATION_SCHEMA.TABLES 中提供这些信息吗?没那么简单! 我想知道 MySQL 表在磁盘上占用多少空间,但看起来很琐碎。不应...

Linux就该这么学
今天
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部