`

实战SPECjvm2008

    博客分类:
  • Java
 
阅读更多

     SPECjvm2008是一个观测JRE运行性能的基准测试套件。它的测试用例涵盖了大部分java基础应用场景,是架构选型和JVM性能评测不可多得的利器。 

SPECjvm2008 官方网站 : http://www.spec.org/

 

1、安装jdk 

1.1 切换到root账号(能够有修改/etc/profile的权限的用户)

 

1.2 下载和安装jdk

把jdk安装在/home/user/runtime/中,把jdk-6u27-linux-x64.bin拷贝到/home/user/runtime/当中。

[root@localhost Desktop]# ./jdk-6u27-linux-x64.bin 回车,然后是同意协议,直接空格过去,然后点击enter,安装完毕。

 

1.3 修改/etc/profile  [root@localhost Desktop]#     vi /etc/profile    增加以下几行 export使变量生效

export JAVA_HOME=/home/fangming/runtime/jdk1.6.0_27

export CLASSPATH=.:$JAVA_HOME/jre/lib/rt.jar:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar

export PATH=$PATH:$JAVA_HOME/bin

 

1.4 修改保存后,重新加载一次

[root@localhost Desktop]#source /etc/profile(当然可以reboot)

 

1.5 验证一下,环境变量是否设置正确

[root@localhost Desktop]# java -version

java version "1.6.0_27"

Java(TM) SE Runtime Environment (build 1.6.0_27-b07)

Java HotSpot(TM) 64-Bit Server VM (build 20.2-b06, mixed mode)

 

1.6 至此jdk已经安装成功

 

2、SPECjvm2008安装

 

2.1  下载SPECjvm2008

下载完成后,是一个“SPECjvm2008_1_01_setup.jar”的安装包,可以前往SPECjvm2008官网进行下载。

 

2.2 安装SPECjvm2008

 linux环境下添加参数-i console,使用命令行的方式进行安装,然后一步一步按照提示安装即可。命令如下:

$ java -jar SPECjvm2008_1_01_setup.jar -i console

 

2.3 验证SPECjvm2008是否安装成功

在安装目录下找到脚本run-specjvm.sh,./run-specjvm.sh startup.helloworld -ikv

startup.helloworld 用于测试helloworld程序的启动时间,选择这个测试用例是考虑到运行速度比较快。 -ikv的意思是跳过签名检查,这个过程比较慢,这里仅仅是测试SPECjvm。

 [user@localhost SPECjvm2008]$ ./run-specjvm.sh startup.helloworld -ikv

 

SPECjvm2008 Base

  Properties file:   none

  Benchmarks:        startup.helloworld

 

  WARNING: Run will not be compliant.

  Not a compliant sequence of benchmarks for publication.

  Property specjvm.run.checksum.validation must be true for publication.

 

 

--- --- --- --- --- --- --- --- ---

 

  Benchmark:   check

  Run mode:    static run

  Test type:   functional

  Threads:     1

  Iterations:  1

  Run length:  1 operation

 

Iteration 1 (1 operation) begins: Tue Apr 01 19:10:43 PDT 2014

Iteration 1 (1 operation) ends:   Tue Apr 01 19:10:44 PDT 2014

Iteration 1 (1 operation) result: PASSED

 

Valid run!

 

 

--- --- --- --- --- --- --- --- ---

 

  Benchmark:   startup.helloworld

  Run mode:    static run

  Test type:   single

  Threads:     1

  Iterations:  1

  Run length:  1 operation

 

Iteration 1 (1 operation) begins: Tue Apr 01 19:10:44 PDT 2014

Iteration 1 (1 operation) ends:   Tue Apr 01 19:10:44 PDT 2014

Iteration 1 (1 operation) result: 194.17 ops/m

 

Valid run!

Score on startup.helloworld: 194.17 ops/m

 

Results are stored in: 

/home/fangming/runtime/SPECjvm2008/results/SPECjvm2008.001/SPECjvm2008.001.raw

Generating reports in:

/home/fangming/runtime/SPECjvm2008/results/SPECjvm2008.001

 

Noncompliant composite result: 194.17 ops/m

 

2.3 SPECjvm2008已经成功安装。

 

3、SPECjvm2008测试用例列表

 

SPECjvm2008测试用例列表:(单位 ops/m 每分钟操作数)

startup.helloworld 测试helloworld程序从运行开始到结束所需的时间
startup.compiler.compiler 普通java编译所需要的时间
startup.compiler.sunflow 编译sunflow图像渲染引擎所需要的时间
startup.compress 测试压缩程序,单次压缩所需的时间
startup.crypto.aes 测试AES/DES加密算法,单次加解密所需的时间
输入数据长度为 100 bytes , 713KB
startup.crypto.rsa 测试RSA加密算法,单次加解密需要的时间
输入数据长度为 100 bytes, 16KB
startup.crypto.signverify 测试单次使用MD5withRSA, SHA1withRSA, SHA1withDSA, SHA256withRSA来签名,识别所需要的时间。
输入数据长度为 1KB, 65KB, 1MB
startup.mpegaudio 单次mpeg音频解码所需的时间
startup.scimark.fft 单次快速傅立叶变换所需的时间
startup.scimark.lu 单次LU分解所需的时间
startup.scimark.monte_carlo 单次运行蒙特卡罗算法所需的时间
startup.scimark.sor 单次运行jacobi逐次超松弛迭代法所需的时间
startup.scimark.sparse 单次稀疏矩阵乘积所需的时间
startup.serial 单次通过socket传输java序列化对象到对端反序列化完成所需的时间(基于jboss serialization benchmark)
startup.sunflow 单次图片渲染处理所需的时间
startup.xml.transform 单次xml转换所需的时间,转换包括dom,sax,stream方式
startup.xml.validation 单次xml schema校验所需的时间
compiler.compiler 在规定时间内,多线程迭代测试普通java编译,得出 ops/m
compiler.sunflow 在规定时间内,多线程迭代测试sunflow图像渲染,得出 ops/m
compress 在规定时间内,多线程迭代测试压缩,得出 ops/m
crypto.aes 在规定时间内,多线程迭代测试AES/DES加解密算法,得出 ops/m
crypto.rsa 在规定时间内,多线程迭代测试RSA加解密算法,得出 ops/m
crypto.signverify 在规定时间内,多线程迭代测试使用MD5withRSA, SHA1withRSA, SHA1withDSA, SHA256withRSA来签名,识别,得出 ops/m
derby 在规定时间内,迭代测试数据库相关逻辑,包括数据库锁,BigDecimal计算等,最后得出 ops/m
mpegaudio 在规定时间内,多线程迭代mpeg音频解码,得出 ops/m
scimark.fft.large 在规定时间内,多线程迭代测试快速傅立叶变换,使用32M大数据集,最后得出 ops/m
scimark.lu.large 在规定时间内,多线程迭代测试LU分解,使用32M大数据集,最后得出 ops/m
scimark.sor.large 在规定时间内,多线程迭代测试jacobi逐次超松弛迭代法,使用32M大数据集,最后得出 ops/m
scimark.sparse.large 在规定时间内,多线程迭代测试稀疏矩阵乘积,使用32M大数据集,最后得出 ops/m
scimark.fft.small 在规定时间内,多线程迭代测试快速傅立叶变换,使用512K小数据集,最后得出 ops/m
scimark.lu.small 在规定时间内,多线程迭代测试LU分解,使用512KB小数据集,最后得出 ops/m
scimark.sor.small 在规定时间内,多线程迭代测试jacobi逐次超松弛迭代法,使用512KB小数据集,最后得出 ops/m
scimark.sparse.small 在规定时间内,多线程迭代测试稀疏矩阵乘积,使用512KB小数据集,最后得出 ops/m
scimark.monte_carlo 在规定时间内,多线程迭代测试蒙特卡罗算法,得出 ops/m
serial 在规定时间内,多线程迭代测试通过socket传输java序列化对象到对端反序列化(基于jboss serialization benchmark),得出 ops/m
sunflow 在规定时间内,利用sunflow多线程迭代测试图片渲染,得出 ops/m
xml.transform 在规定时间内,多线程迭代测试xml转换,得出 ops/m
xml.validation 在规定时间内,多线程迭代测试xml schema验证,得出 ops/m

 

参考文章:

SPECjvm2008 FAQ  http://www.spec.org/jvm2008/docs/FAQ.html  

将SPECjvm2008测试样例引入程序  http://www.dullong.com/introduce-spec-into-my-code.html

描述常用的benchmark和性能评估相关内容 http://www.docin.com/p-366727065.html

 

分享到:
评论

相关推荐

    JVM Spec PDF

    Java虚拟机(JVM)是Java程序运行的基础,它是一个执行环境,负责解析并执行Java字节码。JVM Spec PDF,即Java虚拟机规范,是官方提供的详细文档,用于解释JVM的工作原理、内存模型、类加载机制、垃圾收集以及如何...

    SPECjbb2005.zip_spec cpu_自动化测试

    标题中的"SPECjbb2005.zip_spec cpu_自动化测试"表明这是一个关于评估CPU性能的自动化测试套件,基于SPECjbb2005标准。这个压缩包包含了一个用于测试虚拟机CPU性能的自动化测试脚本。 SPEC(Standard Performance ...

    Java虚拟机中冷对象的研究_骆凡.caj

    java 作为现在用户最多,使用最为广泛的技术,主要是由于一个大大降低开发成 本的优点:它是运行在 java ...SPECjvm2008 的基准表示出来。根据不同的标准测试得垃圾回收小效率有 2%-5% 的提升。

    Java虚拟机中的动态锁cache优化.pdf

    实验结果表明,使用动态锁cache优化方法可以使SPECjvm2008运行时的cache失效次数平均降低8.5%,性能平均提高49.6%。因此,动态锁cache优化方法可以作为Java虚拟机中的一个重要优化技术。 JVM中的锁cache机制可以...

    Java虚拟机中的只读锁优化.pdf

    性能测试用例包括单线程Java程序、多线程Java程序以及SPECjvm2008。实验结果表明,上述优化方法能够极大降低线程进入和退出只读临界区域的开销,提高Java虚拟机的同步性能。 Java虚拟机中的只读锁优化可以极大地...

    在静态编译器中实现Java异常机制的算法.pdf

    通过使用 SPECjvm98 测试集,可以验证在静态编译器中实现 Java 异常机制的算法的正确性和效率,并确保算法的可靠性和可移植性。 在静态编译器中实现 Java 异常机制的算法可以提高 Java 程序的执行效率和可靠性。...

    用代码缓存复用技术提升Android即时编译器效率.pdf

    4. 通过SPECjvm 98测试套件进行了全面的实验,从性能提升、代码膨胀和缓存空间大小三个方面评估了CCARF的效果。结果显示,在平均代码膨胀率为6%的情况下,CCARF可以将SPECjvm 98测试程序的平均性能提升约11.7%。 总...

    Design of the Java HotSpot.pdf

    根据 SPECjvm98enchmark 套件的测试结果,新的客户端编译器可以生成更好的代码,並且编译速度提高了 40%。这表明,选择合适的一组全局优化可以提高编译速度和代码质量。 研究项目 该论文还介绍了几个研究项目,...

    IBM System p, BladeCenter产品性能介绍

    此外,报告还包括了SPECsfs97_R1文件服务器基准测试、NotesBench测试,以及Java性能基准测试(如SPECjvm98、SPECjbb2000、SPECjbb2005),这些都是评估服务器在不同应用场景下性能的重要指标。最后,ECperf基准测试...

    Cloud System OSv

    - **性能对比**:在SPECJVM、MemCacheD、Cassandra等基准测试中,OSv的表现优于Linux等传统操作系统。 ##### 4.3 性能亮点 - **启动时间**:OSv能够在1秒内启动完成。 - **文件系统**:内置了高性能的ZFS文件系统。...

Global site tag (gtag.js) - Google Analytics