实战SPECjvm2008

     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

 

你可能感兴趣的:(2008)