JMeter测试HBase
在网上找了关于jmeter连接hbase的方式,主要分为两种:通过导入jar包连接(Java Request)和通过BeanShell远程连接,由于刚接触jmeter没多久,对BeanShell还不熟,所以打算通过eclipse用Java编写连接hbase的程序并打包成jar包,导入到jmeter的方式连接hbase。
HBase本地远程连接HBase是测试成功的,一开始采用直接打包成runnable jar的方式导入到jmeter,但是创建Java Request之后,页面查不到创建好的接口,后来网上查询到,需要专门写一个程序继承“AbstractJavaSamplerClient”类,jmeter才能识别。
1、创建Java工程
新创建一个Java工程或者在需要调用的工程上创建个类,将ext目录下ApacheJMeter_core.jar、ApacheJMeter_java.jar引入项目(若提示无法找到org/apache/jorphan/logging/LoggingManager接口,需要同时引入lib目录下的jorphan.jar包);
继承AbstractJavaSamplerClient类,并重写以下方法:
public Arguments getDefaultParameters();设置可用参数及的默认值;
public void setupTest(JavaSamplerContext arg0):每个线程测试前执行一次,做一些初始化工作;
public SampleResult runTest(JavaSamplerContext arg0):开始测试,从arg0参数可以获得参数值;
public void teardownTest(JavaSamplerContext arg0):测试结束时调用;
具体接口如下:
package main.jmeter; import java.io.IOException; import org.apache.hadoop.hbase.KeyValue;
import org.apache.hadoop.hbase.client.HTable;
import org.apache.hadoop.hbase.client.Result;
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 main.hbase.HBaseDAO; public class Create extends AbstractJavaSamplerClient {
private String tableName = null;//表名
private String rowkey = null; //rowkey值
private SampleResult results; /**
* 设置传入参数
* 可以设置多个,已设置的参数会显示到Jmeter参数列表中
*/
@Override
public Arguments getDefaultParameters() {
Arguments params = new Arguments();
params.addArgument("tableName","");
params.addArgument("rowkey","");
return params;
} /**
* 初始化方法,初始化性能测试时的每个线程
* 实际运行时每个线程仅执行一次,在测试方法运行前执行,类似于LoadRunner中的init方法
*/
@Override
public void setupTest(JavaSamplerContext context) {
results = new SampleResult();
tableName = context.getParameter("tableName");//注意:此处是接收jmeter的参数传入,需要用引号括起来,否则读取不到值
if(tableName != null && tableName.length() > 0){
results.setSamplerData(tableName);
}
rowkey = context.getParameter("rowkey");
if(rowkey != null && rowkey.length() > 0){
results.setSamplerData(rowkey);
}
}; /**
* 性能测试时的线程运行体
* 测试执行的循环体,根据线程数和循环次数的不同可执行多次,类似于Loadrunner中的Action方法
*/
@SuppressWarnings("deprecation")
@Override
public SampleResult runTest(JavaSamplerContext arg0) {
boolean success = false;
results.sampleStart();
HBaseDAO hbase = new HBaseDAO();
HTable table = hbase.getHTable(tableName);
// getRow 根据rowkey获取所有版本记录
Result r;
try {
r = hbase.getRowVersions(table, rowkey,1);
KeyValue[] kv = r.raw();
for(KeyValue value:kv){
results.setDataEncoding("UTF-8");
results.setResponseData("运行结果 : value = " + new String(value.getValue()));
success = true;
}
} catch (Exception e) {
e.printStackTrace();
} finally {
try {
table.close();
results.sampleEnd();
results.setSuccessful(success);
} catch (IOException e) {
e.printStackTrace();
}
}
return results;
} /**
* 测试结束方法,结束测试中的每个线程
* 实际运行时,每个线程仅执行一次,在测试方法运行结束后执行,类似于Loadrunner中的End方法
*/
@Override
public void teardownTest(JavaSamplerContext arg0) { } }
2、打包并导入
将编辑好的Java项目打成jar包:Export->JAR file->finish
将导出的jar包放入\lib\ext目录下
3、运行JMeter
打开jmeter,点击测试计划将HBase依赖的所有jar包加入环境(建议先拷贝至ext目录下),添加线程组、Java Request
在类名称中找到自己创建的类,参数列表会自动显示类中自定义的参数,填入要测试的值(可添加CSV配置元件,通过参数方式传入);
添加察看结果树、聚合报告,看是否能正常运行,若有异常,点击右上角三角符号查看原因
若遇到java.io.IOException: Could not locate executable null\bin\winutils.exe in the Hadoop binaries.异常,是由于找不到hadoop.home.dir的路径;
我本地运行连接hbase是正常的,但是导入到JMeter之后报个这个异常,我们集群用的是Hadoop 2.6.0,所以从网上下载了个Apache Hadoop Common 2.6.0:https://github.com/amihalik/hadoop-common-2.6.0-bin
解压到本地,然后在HBase的初始化程序中添加(也可配置环境变量)
System.setProperty("hadoop.home.dir", "D:\\Hadoop\\hadoop-common-2.6.0");
重新打包后运行正常。
JMeter测试HBase的更多相关文章
- 用JMeter测试monggodb的请求
JMeter测试MongoDB性能有两种方式,一种是利用JMeter直接测试MongoDB[即通过MongoDB协议测试],另一种是写Java代码方式测试MongoDB[即通过java请求测试] 注: ...
- JMeter学习(十九)JMeter测试MongoDB
JMeter测试MongoDB性能有两种方式,一种是利用JMeter直接进行测试MongoDB,还有一种是写Java代码方式测试MongoDB性能. 第一种方法 1.编写Java代码,内容如下: pa ...
- Jmeter测试webocket协议
Jmeter本身不支持websocket协议的,所以需要安装第三方的插件还有6个依赖包. 首先,我们需要准备Jmeter的WebSocket协议的支持插件: JMeterWebSocketSample ...
- JMeter 测试Web登录
JMeter测试 前置条件: 1安装JMeter 下载地址:http://jmeter.apache.org/ 2安装badBoy http://www.badboy.com.au/download/ ...
- Windows 7下搭建Jmeter测试环境
jmeter配置.安装 一. 工具描述 apache jmeter是100%的java桌面应用程序,它被设计用来加载被测试软件功能特性.度量被测试软件的性能.设计jmeter的初衷是测试web应用,后 ...
- 【jmeter】JMeter测试MongoDB
JMeter测试MongoDB性能有两种方式,一种是利用JMeter直接进行测试MongoDB,还有一种是写Java代码方式测试MongoDB性能. 第一种方法 1.编写Java代码,内容如下: pa ...
- jmeter测试本地myeclips调试状态下的tomcat程序死锁
在myeclipse调试状态下的tomcat程序,用jmeter测试,居然发生死锁,调试两天无果,直接运行tomcat而不通过myeclipse,无死锁,真是又好气又好笑..
- 性能测试工具比较:LoadRunner vs JMeter - 测试结果数据比较
对web请求(HTTP/HTML)进行性能测试,确认请求响应时间.分别使用Loadrunner和JMeter进行测试,比较测试结果. 1.LoadRunner测试web请求响应时间 1.1 编制(录 ...
- jmeter测试dubbo接口
本文讲解jmeter测试dubbo接口的实现方式,文章以一个dubbo的接口为例子进行讲解,该dubbo接口实现的功能为: 一:首先我们看服务端代码 代码架构为: 1:新建一个maven工程,pom文 ...
随机推荐
- 123457123456#1#----com.MC.EnglishGame98--前拼后广--jp英语-mc
com.MC.EnglishGame98--前拼后广--jp英语-mc
- Spring Boot与MyBatis的集成
SSM(Spring+Spring MVC+MyBatis)是当前主流的框架组合开发方式之一,普遍被应用于互联网项目中.如果要使用Spring Boot开发一个基于SSM框架的应用,那么我们要怎么做呢 ...
- yaml文件实例:nginx+ingress
[root@lab3 nginx]# cat nginx-test.yaml apiVersion: extensions/v1beta1 kind: Deployment metadata: nam ...
- 【Leetcode_easy】905. Sort Array By Parity
problem 905. Sort Array By Parity solution1: class Solution { public: vector<int> sortArrayByP ...
- 【linux学习笔记三】链接命令
链接命令:ln link =============华丽的分割线============= ln又有软链接和硬链接 //硬链接特征(不建议创建硬链接) 1.拥有相同的i节点和存储block块,可以看做 ...
- consul(一)什么是consul
1. consul的基本介绍 在分布式架构中,服务治理是一个重要的问题.在没有服务治理的分布式集群中,各个服务之间通过手工或者配置的方式进行服务关系管理,遇到服务关系变化或者增加服务的时候,人肉配置极 ...
- SQL触发器中的inserted表和deleted表
开发也有年头了,但是触发器确实用的比较少,但是无容置疑触发器确实不错, 最近项目要求需要用到的触发器特别多.频繁,觉得很有必要记录和积累下. 在触发器语句中用两个特殊的表一个是deleted表和ins ...
- C/C++ 多线程(程序猿面试重点)CodeBlocks-CB的pthreads使用
C++ 多线程 本文主要讲一下C++多线程 线程好处 ·使用线程可以把占据长时间的程序中的任务放到后台去处理 ·程序的运行速度可能加快 可以释放一些珍贵的资源如内存占用等等. 但是多线程是为了同步完成 ...
- springboot的mapper.xml在src下问题
在pom.xml里面的build标签加上resources说明 <resources> <!-- mapper.xml文件在java目录下 --> <resource&g ...
- 2019.10.28 IDEA入门指南(很多人问补充一篇)
Idea快速入门指南 1.安装 1.1.安装 我们使用的是最新的2017.3.4版本: 双击打开, 选择一个目录,最好不要中文和空格: 然后选择桌面快捷方式,请选择64位: 然后选择安装: 开始安装: ...