文档章节

使用JMeter做压力测试

今幕明
 今幕明
发布于 2015/03/30 20:06
字数 1272
阅读 511
收藏 3

使用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

今幕明
粉丝 47
博文 230
码字总数 39350
作品 0
朝阳
程序员
私信 提问
JMeter学习-001-JMeter初识

Apache JMeter是Apache组织开发的基于Java的开源压力测试工具(个人发现也可用于接口测试)。用于对软件做压力测试,它最初被设计用于Web应用测试但后来扩展到其他测试领域。 它可以用于测试...

拎壶冲冲冲
2018/05/29
0
0
使用Jmeter自动化压测TCP Server经验

使用Jmeter自动化压测TCP Server经验 • Jmeter简介 • Jemter的主要功能 • Jmeter TCP发送方式 • Jmeter 测试TCP配置 • Jmeter快速上手使用 1、Jmeter简介 Apache JMeter是Apache组织开发...

HowieXue
03/20
0
0
个人之在团队中默默的推行jmeter的使用

前言 一, 测试不高效,也妨碍的老胡打杂的不高效,得加班。 二, 一些真正的好东西,推广,自己成长,其他人一起成长三, 高效的团队,合作很愉快,自己真的舒服。不会为了小事,无效的折腾...

鸟菜啊
04/08
55
0
JMeter学习-003-JMeter与LoadRunner的异曲同工

本节主要对 JMeter 与 LoadRunner 的优缺点进行概要的总结,若有不足之处,敬请指正,不胜感激! 同时,我也不得不承认,在对 JMeter 和 LoadRunner 进行比较时,我个人的确偏向了 JMeter(免...

拎壶冲冲冲
2018/06/26
0
0
JMeter和LoadRunner的异同

Notes:最近几天一直在搞测试软件,相继搞了LoadRunner和JMeter,现在和大家分享一下JMeter和LoadRunner的异同 Jmeter和LoadRunner的异同   1、Jmeter的架构跟LoadRunner原理一样,都是通过...

JavaOlder
2013/03/14
1K
0

没有更多内容

加载失败,请刷新页面

加载更多

浅谈prototype原型模式

一、原型模式简介 原型(Prototype)模式是一种对象创建型模式,他采取复制原型对象的方法来创建对象的实例。使用原型模式创建的实例,具有与原型一样的数据。 原型模式的特点: 1、由原型对...

青衣霓裳
5分钟前
1
0
shell mysql 备份

#!/bin/bash time2=$(date "+%Y-%m-%d-%H:%M:%S") /usr/local/mysql/bin/mysqldump -uroot -p ad > /usr/local/mysql/backup/"$time2".sql 变量引用原来是这么用的。......

奋斗的小牛
13分钟前
2
0
Jmeter监控Linux服务器操作

系统:Win7 64位 工具:Jmeter 4.0 要准备好的插件:JMeterPlugins-Standard-1.4.0,ServerAgent-2.2.1 解压JMeterPlugins-Standard-1.4.0.zip,将其中\lib\ext\JMeterPlugins-Standard.jar......

魔鬼妹子
13分钟前
3
0
系列文章:云原生Kubernetes日志落地方案

在Logging这块做了几年,最近1年来越来越多的同学来咨询如何为Kubernetes构建一个日志系统或者是来求助在这过程中遇到一系列问题如何解决,授人以鱼不如授人以渔,于是想把我们这些年积累的经...

Mr_zebra
14分钟前
2
0
入门必备!快速学会用Aspose.Words在表格中插入和删除列!

Aspose.Words For .Net(点击下载)是一种高级Word文档处理API,用于执行各种文档管理和操作任务。API支持生成,修改,转换,呈现和打印文档,而无需在跨平台应用程序中直接使用Microsoft W...

mnrssj
19分钟前
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部