【转】JMeter完成一个java请求的压测
JMeter完成java请求的压力测试详解以及问题总结
原文地址:http://www.cnblogs.com/zhaoxd07/p/4895224.html 作者:KK_Yolanda
这篇文章已经写得比较全面了,所以转载下,自己懒得总结了, 只对部分做了修改。
先定义一下我说的remoteService:即远程调用服务,没有http的url。不对外提供或者对外提供有限的服务。具体视各公司的代码架构所定,比如有些公司为web工程,scf服务,db。scf即为服务通讯框架(Service Communication Framework)该层结构,或者一些单独的lib包,里面集成了某些方法
对于有url的http请求,我们可以用jmeter的http请求进行压测,或者使用Apache-AB等进行测试,这种也可以用JMeter进行压力测试,具体操作如下
核心步骤
1.创建一个Java工程;
2.将JMeter的lib目录下的jar文件添加进此工程的Build Path;
3.创建一个类并实现JavaSamplerClient接口或继承AbstractJavaSamplerClient,并重写;
public Arguments getDefaultParameters();设置可用参数及的默认值;
public void setupTest(JavaSamplerContext arg0):每个线程测试前执行一次,做一些初始化工作;
public SampleResult runTest(JavaSamplerContext arg0):开始测试,从arg0参数可以获得参数值,执行多次依赖于设置方式;
public void teardownTest(JavaSamplerContext arg0):测试结束时调用,只执行一次;
4.Export为Runnable Jar File;
5.将此jar包放入JMETER_HOME\lib\ext目录;
6.以管理员身份打开JMeter;
7.创建线程组、Java Request、查看结果树,进行测试;
public Arguments getDefaultParameters();设置可用参数及的默认值;
public void setupTest(JavaSamplerContext arg0):每个线程测试前执行一次,做一些初始化工作;
public SampleResult runTest(JavaSamplerContext arg0):开始测试,从arg0参数可以获得参数值,执行多次依赖于设置方式;
public void teardownTest(JavaSamplerContext arg0):测试结束时调用,只执行一次;
@Override
public Arguments getDefaultParameters(){
Arguments params = new Arguments();
params.addArgument( "localPath", "1");
params.addArgument( "catePath", "9224,13901");
params.addArgument( "pn", "1");
params.addArgument( "platform", "-1");
params.addArgument( "referer", "referer");
params.addArgument( "userAgent", "userAgent");
params.addArgument( "ip", "1.1.1.1"); return params;
}
@Override
public void setupTest(JavaSamplerContext arg0){
results = new SampleResult();
localPath = arg0.getParameter( "localPath");
catePath = arg0.getParameter( "catePath");
pn = Integer. parseInt(arg0.getParameter("pn"));
platform = Integer. parseInt(arg0.getParameter("platform"));
referer = arg0.getParameter( "referer");
userAgent = arg0.getParameter( "userAgent");
ip = arg0.getParameter( "ip");
}
public SampleResult runTest(JavaSamplerContext arg0){
results = new SampleResult();//初始化记录结果
results.sampleStart();//计时开始
/*测试方法*/此处写自己的测试方法进行调用
List<MingQiInfo> mingQiInfos = scf.loadMingQiInfo( localPath, catePath, pn, platform, referer, userAgent, ip);
results.sampleEnd();//计时结束
//判断测试成功与否的方法:可根据实际进行判断,此处为如果结果非空,则认为改次调用成功
if (mingQiInfos!= null) {
results.setSuccessful( true);
for(MingQiInfo sssInfo :mingQiInfos){ //将结果写入结果树:在jmeter的监听器-查看结果树时即可查看返回结果
resultData += String. valueOf(sssInfo.toString());
}
results.setResponseData( "结果是:"+resultData ,null);
results.setDataType(SampleResult. TEXT);
}
else {
results.setSuccessful( false);//不满足判断条件则判为false,会出现在监听器-聚合报告的Error%列
}
return results;
}
4)、tearDownTest:测试结束后的操作(这里什么也不做)
更改内存设置,linux环境,修改jmeter.sh;windows环境,更改jmeter.bat文件,增大配置内存:
set HEAP=-Xmx1024m -Xms512m -Xmn256m -Xss128k //如果值太大,则jmeter会打不开,同时会有提示;值太小则有OutOfMemory的错误
set PERM=-XX:PermSize=64m -XX:MaxPermSize=128m -XX:+CMSClassUnloadingEnabled
‘View Result Tree’-查看结果树 在debug的时候非常的好用,但是也很占内存。所以在跑性能测试的时候还是不要用的为好。 1 占用内存:本来跑30分钟不到就有OutOfMemory的错误,把 ‘View Result Tree’ 这个listener删掉后,就再也没有出现 2 影响聚合报告的结果:写结果树占用时间和资源
问题3:执行debug程序时报错
检查下jmeter是否为中文路径,如果有,统一改成英文路径
问题4:配置文件获取不到或者失败,无法初始化
注意:在写初始化方法时,注意配置文件最好写成绝对路径;写成相对路径时,需要把配置放到jmeter对应的路径下。我比较习惯用相对路径“System.getProperty("user.dir")”,就需要把配置放到/jmeter/bin里面去。
问题5:调试一个问题时,我打印了初始化日志,发现每次鼠标点击“java请求”,都会初始化4次
初始化4次的解释:4个jmeter重载的函数,runTest setupTest getArgument tearDown,每个都会去初始化一次。
每次点击"java请求"都做初始化:是因为我在定义全局变量建立tcp连接时没有定义为"public static". 修改后解决。
我定义了一个全局变量:int count;
在setupTest方法里设置“count = arg0.getParameter("count");”时提示
change type of 'count' to 'string'
解决办法:arg0.可以联想出来getIntParameter和getLongParameter用以添加不同的数据类型,count = arg0.getIntParameter("count"); 即 ok。
重写getLogger方法,如:
public org.apache.log.Logger getLogger()
{ return super.getLogger(); }
使用:
this.getLogger().info(">>>>>>>>>> runTest() >>>>>>>>>>");这样就可以在jmeter日志里边打印出相关日志信息,见下图:
SampleResult results=new SampleResult();
results.setSampleLabel("Test2222");
results.sampleStart();
results.setSuccessful(true);
results.sampleEnd();
如果没有设置results.setSuccessful() 默认执行结果是错误Error,所以这个可以更具逻辑判断来输出结果是正确或错误
SampleResult results=new SampleResult();
results.setSampleLabel("Test2222");
results.sampleStart();
results.setSuccessful(true);
results.sampleEnd();
如果没有设置results.setSuccessful() 默认执行结果是错误Error,所以这个可以更具逻辑判断来输出结果是正确或错误,见下图
【转】JMeter完成一个java请求的压测的更多相关文章
- 【JMeter】JMeter完成一个java请求的压测
先定义一下我说的remoteService:即远程调用服务,没有http的url.不对外提供或者对外提供有限的服务.具体视各公司的代码架构所定,比如有些公司为web工程,scf服务,db.scf即为服 ...
- 性能测试十一:jmeter进阶之java请求
使用Java编写JDBC脚本对Mysql进行增删改查等操作的性能测试 使用Jmeter提供的脚本框架依赖的jar包(分别在jmeter目录下的lib和ext目录下) ApacheJMeter_core ...
- jmeter之自定义java请求性能测试
一.环境准备 1.新建一个java工程 2.导入jar包:ApacheJMeter_core.jar ApacheJMeter_java.jar ...
- jmeter中实现java请求实战日志
view code public class JdbcInsert implements JavaSamplerClient { // 全局变量 PreparedStatement pstmt; Co ...
- 软件性能测试分析与调优实践之路-JMeter对RPC服务的性能压测分析与调优-手稿节选
一.JMeter 如何通过自定义Sample来压测RPC服务 RPC(Remote Procedure Call)俗称远程过程调用,是常用的一种高效的服务调用方式,也是性能压测时经常遇到的一种服务调用 ...
- Jmeter 在linux下的分布式压测
Jmeter 在linux下的分布式压测 0.将 windows机器作为master 控制机(同时也兼做负载机slave), linux机器作为 负载机 slave. 1.linux环境安装 : (1 ...
- jmeter对数据库进行简单的压测
1.点击测试计划,再点击“浏览”,把JDBC驱动添加进来: 注:JDBC驱动一般的位置在java的安装地址下,路径类似于: \java\jre\lib\ext 文件为:mysql-connect ...
- 性能测试十二:jmeter进阶之java请求参数化
如项目中的ip.端口号之类的,都可以在此代码中定义 public Arguments getDefaultParameters() { // TODO Auto-generated method st ...
- Jmeter创建一个http请求
1.点击'Test Plan'为测试计划命名为"创建用户接口" 2.新建一个[线程组],在[创建用户接口]处点击右键,选择[添加]-->[Threads(Users)]--& ...
随机推荐
- Android 版本对于 API
Android版本 API 代号 官网链接 Android 2.3.3 API 10 Gingerbread 官网 Android 3.0 API 11 Android 3.1 API 12 Andr ...
- redis中键空间通知
通过redis的键空间通知,当redis删除过期key的时候,及时更新mongodb数据库中user的状态 var Redis = require('ioredis'); var redis = ne ...
- mongodb更新数组中的所有匹配项
假如集合中有如下数据 { "_id" : ObjectId("4b97e62bf1d8c7152c9ccb74"), "title" : & ...
- 关于CAE的那点儿破事儿
CAE是计算机辅助工程的英文简写,所涵盖的范围甚是广泛.现在很多人提到CAE,总是联想到结构有限元计算,更有甚者认为有限元就是CAE.还有人把所有的工程数值计算都称作有限元.本文就这一话题,来谈谈关于 ...
- 每日英语:Nelson Mandela Dies at 95
Nelson Mandela, who rose from militant antiapartheid activist to become the unifying president of a ...
- UnicodeDecodeError: 'ascii' codec can't decode byte 0xa3 in position 1: ordinal not in range(128)
使用codecs模块 codecs模块能在处理字节流的时候提供很大帮助.你可以用定义的编码来打开文件并且你从文件里读取的内容会被自动转化为Unicode对象. 试试这个: >>> i ...
- DjangoUeditor 使用七牛云存储
DjangoUeditor 是一个相当赞的django 富文本编辑器,你可以在 https://github.com/zhangfisher/DjangoUeditor 查看相关信息. 我一直想着把D ...
- MyBatisBatchItemWriter Cannot change the ExecutorType when there is an existing transaction
但凡使用mybatis,同时与spring集成使用时,接下来要说的这个问题是躲不了的.众所周知,mybatis的SqlSessionFactory在获取一个SqlSession时使用默认Executo ...
- [转]Oracle 语法之 OVER (PARTITION BY ..) 及开窗函数
oracle的分析函数over 及开窗函数 一:分析函数Oracle从8.1.6开始提供分析函数,分析函数用于计算基于组的某种聚合值,它和聚合函数的不同之处是 对于每个组返回多行,而聚合函数对于每个组 ...
- 数据库like匹配的实现猜测
insert into test_fulltext values("王正科技全文") select * from test_fulltext where data like &qu ...