[转]比较Jmeter、Grinder和JAVA多线程本身压力测试所带来的性能开销
1. 测试环境
jmeter版本 :jmeter 2.4
grinder的版本 : Grinder 3
JAVA的版本:JDK 1.6
2. 测试代码
Jmeter测试代码
- public class Sampler {
- public void test() {
- return;
- }
- }
- public class JmeterTest extends AbstractJavaSamplerClient {
- Sampler sampler;
- @Override
- public SampleResult runTest(JavaSamplerContext context) {
- SampleResult results = new SampleResult();
- results.sampleStart();
- sampler.test();
- results.sampleEnd();
- results.setSuccessful(true);
- return results;
- }
- @Override
- public void setupTest(JavaSamplerContext arg0) {
- sampler = new Sampler();
- }
- }
grinder测试代码
- public class Sampler {
- public void test() {
- return;
- }
- }
- # Test.py
- #
- # A minimal script that tests The Grinder logging facility.
- #
- # This script shows the recommended style for scripts, with a
- # TestRunner class. The script is executed just once by each worker
- # process and defines the TestRunner class. The Grinder creates an
- # instance of TestRunner for each worker thread, and repeatedly calls
- # the instance for each run of that thread.
- from net.grinder.script.Grinder import grinder
- from net.grinder.script import Test
- from sampler import Sampler
- test = Test(1, "Sample")
- class TestRunner:
- # This method is called for every run.
- def __call__(self):
- mySampler = test.wrap(Sampler())
- mySampler.test()
Java本身多线程
- public static void test(int numOfThreads, int times) throws InterruptedException, ExecutionException {
- ExecutorService executor = Executors.newFixedThreadPool(numOfThreads);
- final Sampler sampler = new Sampler();
- List<Future<Long>> results = new ArrayList<Future<Long>>();
- for (int i = 0; i < times; i++) {
- results.add(executor.submit(new Callable<Long>() {
- @Override
- public Long call() throws Exception {
- long begin = System.currentTimeMillis();
- sampler.test();
- long end = System.currentTimeMillis();
- return end - begin;
- }
- }));
- }
- executor.shutdown();
- while(!executor.awaitTermination(1, TimeUnit.SECONDS));
- long sum = 0;
- for (Future<Long> result : results) {
- sum += result.get();
- }
- System.out.println("---------------------------------");
- System.out.println("number of threads :" + numOfThreads + " times:" + times);
- System.out.println("running time: " + sum + "ms");
- System.out.println("TPS: " + (double)(100000 * 1000) / (double)(sum));
- System.out.println();
- }
3. 测试结果
10个线程 100000次运行
-- | TPS |
Jmeter | 50426.10 |
Grinder | 290275.76 |
Java threads | 2.5E7 |
20个线程 100000次运行
-- | TPS |
Jmeter | 49215.02 |
Grinder | 225402.91 |
Java threads | 2.5E7 |
50个线程 100000次运行
-- | TPS |
Jmeter | 29312.61 |
Grinder | 212242.13 |
Java threads | 2.5E7 |
100个线程 100000次运行
-- | TPS |
Jmeter | 29031.03 |
Grinder | 245507.22 |
Java threads | 2.5E7 |
200个线程 10000次运行(这里减少了一个0)
-- | TPS |
Jmeter | 28039.87 |
Grinder | 232801.77 |
Java threads | 2.5E7 |
300个线程 10000次运行
-- | TPS |
Jmeter | 27208.16 |
Grinder | 236537.10 |
Java threads | 1818181.81 |
1000个线程 10000次运行
-- | TPS |
Jmeter | 27208.16 |
Grinder | 236537.10 |
Java threads | 2.5E7 |
4. 结论
- 可以看出Jmeter的本身性能开销是很大的,只适合一般应用的性能测试
- Grinder在测试的时候发现上下文切换比较严重,而可能是因为内部机制导致的开销较大的,当然如果测试memcache肯定是不适合的,但一般的应用测试基本上没有问题
- JAVA多线程本身并发框架性能开销也是有的,但是比较低,适合要求较高的性能测试,如对redis和memcache构建的应用进行压测
转:http://blog.csdn.net/techq/article/details/6628533
[转]比较Jmeter、Grinder和JAVA多线程本身压力测试所带来的性能开销的更多相关文章
- java基础六 [异常处理](阅读Head First Java记录)
在程序运行时,我们不能保证所有服务和方法都是正确的,如果发生问题报错会导致程序崩溃,所以需要对一些可以预见的错误进行异常处理,通过throw去抛出一个异常,然后用try..catch..将要执行的该方 ...
- Java Collection 集合类大小调整带来的性能消耗
Java Collection类的某些详细实现因为底层数据存储基于数组,随着元素数量的添加,调整大小的代价非常大.随着Collection元素增长到某个上限,调整其大小可能出现性能问题. 当Colle ...
- Java基础 之软引用、弱引用、虚引用 ·[转载]
Java基础 之软引用.弱引用.虚引用 ·[转载] 2011-11-24 14:43:41 Java基础 之软引用.弱引用.虚引用 浏览(509)|评论(1) 交流分类:Java|笔记分类: Ja ...
- Java多线程-新特性-线程池
Sun在Java5中,对Java线程的类库做了大量的扩展,其中线程池就是Java5的新特征之一,除了线程池之外,还有很多多线程相关的内容,为多线程的编程带来了极大便利.为了编写高效稳定可靠的多线程程序 ...
- Java多线程详解
Java线程:概念与原理 一.操作系统中线程和进程的概念 现在的操作系统是多任务操作系统.多线程是实现多任务的一种方式. 进程是指一个内存中运行的应用程序,每个进程都有自己独立的一块内存空间,一个进程 ...
- Java多线程与并发模型之锁
这是一篇总结Java多线程开发的长文.文章是从Java创建之初就存在的synchronized关键字引入,对Java多线程和并发模型进行了探讨.希望通过此篇内容的解读能帮助Java开发者更好的理清Ja ...
- java 多线程和线程池
● 多线程 多线程的概念很好理解就是多条线程同时存在,但要用好多线程确不容易,涉及到多线程间通信,多线程共用一个资源等诸多问题. 使用多线程的优缺点: 优点: 1)适当的提高程序的执行效率(多个线程同 ...
- [转]如何在Java中调用DLL方法
转载地址:http://developer.51cto.com/art/200906/129773.htm Java语言本身具有跨平台性,如果通过Java调用DLL的技术方便易用,使用Java开发前台 ...
- java基础九[网络与线程](阅读Head First Java记录)
网络socket连接 Java API的网络功能包(java.net)已经将底层的TCP连接等都封装好了,我们只需要通过Socket对象来建立客户端和服务器的连接,然后客户端能向服务器发送请求,并接收 ...
随机推荐
- Mac OSX 下用 Homebrew 安装 MongoDB 并配置到 WebStorm 中
1. 安装 Ruby OSX 操作系统内置 Ruby,但如果没有 Ruby,则需先输入以下命令安装能够进行多版本ruby环境安装.管理和切换的命令行工具 RVM. 1.1 安装 RVM 打开终端输入以 ...
- [maven] 生命周期和插件
maven生命周期和插件 生命周期 maven的生命周期有三套,互相独立.每个生命周期含有不同阶段,常用如下 clean 清理项目 pre-clean 执行清理前需要完成的工作 clean 清理上一次 ...
- 【GOF23设计模式】组合模式
来源:http://www.bjsxt.com/ 一.[GOF23设计模式]_组合模式.树状结构.杀毒软件架构.JUnite底层架构.常见开发场景 package com.test.composite ...
- [Tool] Windows 8.1安装SQL Server
[Tool] Windows 8.1安装SQL Server 问题情景 因为工作的关系,需要在Windows 8.1.64Bit设备上安装SQL Server 2012.本来以为是个只要按下一步就可以 ...
- 初次接触mootools
以下是今天所学代码,网上有这篇博客可供参考,另外还是推荐官方文档 ,以下是今天所敲代码: //用mootools创建类的方式: //方式1:用标准方式传入一个对象字面量 /* var Person = ...
- 【使用 DOM】使用事件
1. 使用简单事件处理器 可以用几种不同的方式处理事件.最直接的方式是用事件属性创建一个简单事件处理器(simple event handler).元素为它们支持的每一种事件都定义了一个事件属性.举个 ...
- 当Thread.Sleep的暂停时间参数设置过小时,精度很差的解决方法
一.问题产生 在C#和C++中有这样一个函数:void Sleep(int Timeout),可以让线程暂停指定的毫秒数. 但是我在win8下调用这个函数实现按照固定频率发送udp数据包时,会有一个问 ...
- thinkPHP学习笔记(2)
1.调试模式 设置调试模式部分代码如下: <?php define('APP_DEBUG',TRUE); // 开启调试模式 常量定义代码 require '/ThinkPHP框架所在目录/Th ...
- C# 零散知识 扩展方法 类型约束
今天看到这么一段代码,我看下面调用了NotifyPropertyChanged定义了两个参数,但是调用的时候只写了一个参数.后来查了下,原来这个是扩展方法的用法, 就是说给T扩展了一个方法Notify ...
- Java并发大师Brain Goetz和Doug Lea 的中英文博客文章地址
Java并发大师Brain Goetz和Doug Lea是Java并发方面最权威的人物,他的文章绝对是最具有参考价值的,值得仔仔细细的推敲和研究. Brain Goetz 中文地址:http://ww ...