使用JMeter测试solr请求

一.安装JMeter

在官网http://jmeter.apache.org/download_jmeter.cgi下载JMeter

直接解压JMeter安装包

Linux下运行 $JMETER_HOME/bin/jmeter.sh

Windows下运行  $JMETER_HOME /bin/jmeter.bat 启动图形界面

二.编写JMeter测试类

1.在Eclipse中建立java工程,加入jmeter的一些基础包ApacheJMeter_core.jar,ApacheJMeter_java.jar,这两个jar包在$JMETER/lib/ext下面.同时为了方便调试,还需要加入一些日志包,avalon-framework-4.1.4.jar,commons-logging-1.1.1.jar,jorphan.jar,logkit-2.0.jar,加入之后具有如下的包结构:

2.新建SolrJmeterTest类,并继承AbstractJavaSamplerClient

package test.solr;

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; /**
* 使用Jmeter测试solr请求
*
* @author wuwen
* @date Feb 17, 2013 10:30:55 AM
*
*/
public class SolrJmeterTest extends AbstractJavaSamplerClient { private static String label = "SolrRequest"; // 定义label名称,显示在jmeter的窗口 private SolrRequest solrRequest;
/**
* 定义测试初始值,setupTest只在测试开始前使用,类似于LoadRunner中的init方法
*/
@Override
public void setupTest(JavaSamplerContext context) {
super.setupTest(context);
// System.out.println("setupTest.....");
String url = context.getParameter("url"); // 获取Jmeter中设置的外界参数
solrRequest = SolrRequest.getInstance(url);
} /**
* 参数定义,也可以直接在Jmeter界面手工输入参数
* 代码里面可以通过Map<String, String> map = getDefaultParameters().getArgumentsAsMap()获取相关值
*/
@Override
public Arguments getDefaultParameters() {
Arguments arg = new Arguments();
arg.addArgument("url", "http://172.16.19.68:5631/solr/zw");
arg.addArgument("q", "${q}");
return arg;
} /**
* 测试执行的循环体,根据线程数和循环次数的不同可执行多次,类似于LoadRunner中的Action方法
*/
@Override
public SampleResult runTest(JavaSamplerContext context) {
// System.out.println("runTest....."); // System.out的输出会显示在启动的Jmeter命令窗口内,输出过多会影响性能的准确性
SampleResult results = new SampleResult(); // SampleResult封装了所有测试结果(如:测试是否成功,程序执行时间等)
results.setSampleLabel(label);
boolean success = true;
results.sampleStart(); // 定义一个事务,表示这是事务的起始点,类似于LoadRunner的lr.start_transaction
try {
/** 这里就是需要测试的代码 */
solrRequest.query(context.getParameter("q")); // 调用solr请求
} catch (Exception e) {
e.printStackTrace();
success = false;
} finally {
results.sampleEnd(); // 定义一个事务,表示这是事务的结束点,类似于LoadRunner的lr.end_transaction
results.setSuccessful(success); // false表示失败
} return results;
} /**
* 结束方法,实际运行每个线程仅执行一次,在测试方法运行结束后执行,类似于LoadRunner中的end方法
*/
@Override
public void teardownTest(JavaSamplerContext context) {
super.teardownTest(context);
// System.out.println("teardownTest.....");
} public static void main(String[] args) {
SolrJmeterTest jt = new SolrJmeterTest();
JavaSamplerContext context = new JavaSamplerContext(jt.getDefaultParameters());
// 初始值执行
jt.setupTest(context);
// 执行部分调用
jt.runTest(context);
// 执行结束处理
jt.teardownTest(context);
}
}

3.将工程打包成jar,放到$JMETER_HOME/lib/ext目录下面

4.启动JMeter

三.运行JMeter

1.添加线程组,选中主界面左侧的“测试计划”,右键菜单->添加->Threads(Users)->线程组

线程组面板设置说明:

2.添加java请求,选中刚才新增的"线程组",右键菜单->添加->Sampler->Java请求

java请求面板说明:

在类名称中选择之前打包的jar里面的类即可

3.添加动态参数(CSV Data Set Config设置),选中刚才新增的"JAVA请求",右键菜单->添加->配置元件>CSV Data Set Config

参数设置说明:

Filename:文件名,指保存信息的文件目录,可以相对或者绝对路径(比如:D:\word.txt)

File Encoding --- 文件编码

Variable Names:参数名称(如:有几个参数,在这里面就写几个参数名称,每个名称中间用分隔符分割,分隔符在下面的“Delimitet”中定义,为了和文件中的“,”对于,这里也用“,”分割每个参数名,(比如:use,password)

Delimitet:定义分隔符,如文件中使用的是逗号分隔,则填写逗号;如使用的是TAB,则填写\t

Recycle on EOF? --- True=当读取文件到结尾时,再重头读取文件

False=当读取文件到结尾时,停止读取文件
     Stop thread on EOF? --- 当Recycle on EOF?一项为False时起效;True=当读取文件到结尾时,停止进程

4.结果监听,选中刚才新增的"Java请求",右键菜单->添加->监视器->聚合报告

5.保存测试用例之后,Ctrl + R,开始运行, Ctrl + E,清除历史结果。

6.查看测试结果:

聚合报告中基本已经包含我们所关心的几个数据了:

Samples -- 本次场景中一共完成了多少个Transaction

Average -- 平均响应时间

Median -- 统计意义上面的响应时间的中值

90% Line -- 所有transaction中90%的transaction的响应时间都小于xx

Min -- 最小响应时间

Max -- 最大响应时间

PS: 以上时间的单位均为ms

Error -- 出错率

Troughput -- 吞吐量,单位:transaction/sec

KB/sec -- 以流量做衡量的吞吐量

转:应用JMeter测试solr请求的更多相关文章

  1. jmeter测试HTTP请求

    HTTP超文本传输协议(HyperText Transfer Protocol)是互联网上应用最为广泛的一种网络协议.所有的WWW文件都必须遵守这个标准.(详情参考看一下百科) HTTP发送请求有GE ...

  2. jmeter测试https请求之导入证书

    jmeter测试https请求   公司最近在搞全站HTTPS改造,进一步提高网站的安全性,防止运营商劫持.那么,改造完成后,所有前后端的URL将全部为https. So ,研究下怎么用Jmeter访 ...

  3. jmeter测试https请求

    测试https请求时,需要添加证书 目录 1.下载证书 2.导入 3.执行https请求 1.下载证书 在浏览器中打开要测试的https协议的网站,以谷歌为例打开,下载证书到桌面 4.一直点击下一步 ...

  4. 使用Jmeter测试java请求

    1.性能测试过程中,有时候开发想对JAVA代码进行性能测试,Jmeter是支持对Java请求进行性能测试,但是需要自己开发.打包好要测试的代码,就能在Java请求中对该java方法进行性能测试2.本文 ...

  5. 使用jMeter测试Solr服务接口

    之前一直用ab做简单的服务接口测试,ab功能强悍,使用简单,但是没有生成专题图和表格等功能,因此,我们决定使用jmeter来作为我们测试工具.接下来,我们将详细介绍jmeter使用的步骤,主要包括:j ...

  6. Apache JMeter 测试Http请求

    环境安装:JDK 下载:http://jmeter.apache.org/download_jmeter.cgi 启动: 简单HTTP请求测试

  7. 第二篇--Jmeter测试Java请求

    前提:需要准备eclipse作为开发工具,安装jdk,准备完毕,接下来开工喽! 1.新建Java工程BMIrisJNIJarTest,新建lib目录,将Jmeter安装目录下lib/ext包下的Apa ...

  8. jmeter(二十二)jmeter测试Java请求

    目的:对Java程序进行测试 目录 一.核心步骤 二.实例 三.JMeter Java Sampler介绍 四.自带Java Request Sampler 一.核心步骤 1.创建一个Java工程: ...

  9. jmeter测试http请求使用csv参数

    创建参数化文件 线程组添加CSV Data Set Config配置元件 为请求添加参数 重新运行查看结果 使用随机参数(JMeter有好多函数可以使用) 查看结果发现使用随机生成的数字 3

随机推荐

  1. 解决larave-dompdf中文字体显示问题

    1.安装laravel-dompdf依赖. Packagist:https://packagist.org/packages/barryvdh/laravel-dompdf composer requ ...

  2. 一个初学者的辛酸路程-FTP-9

    前言 今天,我要描述一个FTP的故事 主要内容 嗯,今天主要以阶梯性的形式来做一个FTP项目. 第一步: 我要实现这么一个功能,一个FTP客户端,1个FTP服务端,2端建立连接以后可以进行通讯. 服务 ...

  3. PHP mktime函数获取今天的开始和结束时间戳

    php 获取今日.昨日.上周.本月的起始时间戳和结束时间戳的方法,主要使用到了 php 的时间函数 mktime(). mktime函数用法如下:mktime(hour,minute,second,m ...

  4. C++中Map常见用法以及按照value排序

    今天做一个简单的算法题,居然用了1个小时,STL unordered_map用多了,没想到map这次派上了用场,这里记录一下: 算法题为 给一个字符串例如  abaaba,每连续两个字符组成一个子串 ...

  5. HTML5入门总结 HTML5API

    w3cshools  MDN英文  MDN中文 HTML5 HTML5 is the latest evolution of the standard that defines HTML. The t ...

  6. POJ 2411 Mondriaan's Dream/[二进制状压DP]

    题目链接[http://poj.org/problem?id=2411] 题意:给出一个h*w的矩形1<=h,w<=11.用1*2和2*1的小矩形去填满这个h*w的矩形,问有多少种方法? ...

  7. Android:自定义Dialog大小,显示圆角

    经过测试,可以使用. ----------------------------------------------------------- AlertDialog.Builder builder = ...

  8. C1FlexGrid小结(转自http://www.cnblogs.com/C1SupportTeam/archive/2012/12/11/2812316.html)

    C1FlexGrid控件来对一个表格格式中的数据进行显示,编辑,组和总结.该表格可以绑定到一个数据源,它可以对自己的数据进行管理. C1FlexGrid控件有一个包含以下元素的丰富的对象模型: 以下的 ...

  9. 寻找中位数v1.0

    题目内容: 编写一个函数返回三个整数中的中间数.函数原型为: int mid(int a, int b, int c); 函数功能是返回a,b,c三数中大小位于中间的那个数. 输入格式: " ...

  10. 深入分析Java Web开发

    Web请求过程 如何发起请求:browser,httpclient http解析:chrome ,cache Dns域名解析:域名缓存 cdn:负载,动态加速,回源 Java I/O I/0类库的基本 ...