为什么Open和Oracle JDK之间的Raspberry pi有这么大的性能差异?

时间:2015-07-01 06:00:40

标签: java oracle performance raspberry-pi raspbian

在我的Raspberry上,我使用两个JVM进行了一些性能测试,如CaffeineMark和SciMark。尽管我听说差异非常小,但它们之间存在巨大的性能差异。我也尝试使用浮点数进行计算,并且Oracle JDK获得了更好的分数,即使两者都应该支持硬浮点数abi。

我使用Linux raspberrypi 3.18.11-v7+作为操作系统。

OpenJDK:    
java version "1.7.0_79"  
OpenJDK Runtime Environment (IcedTea 2.5.5) (7u79-2.5.5-1~deb7u1+rpi1)  
OpenJDK Zero VM (build 24.79-b02, mixed mode)  

OracleJDK:  
java version "1.7.0_40"  
Java(TM) SE Runtime Environment (build 1.7.0_40-b43)  
Java HotSpot(TM) Client VM (build 24.0-b56, mixed mode)  

SciMark results:

                 OpenJDK            OracleJDK
Composite Score 14.280735577363213  || 32.24948180361924   
FFT (1024)      9.482866845055302   || 26.447121360843663  
SOR (100x100)   27.14938943220646   || 59.68022533004399  
Monte Carlo     3.6298604956147384  || 10.561671865446971  
Sparse matmult  15.603809523809524  || 26.64931580928407  
LU (100x100)    15.53775159013005   || 37.90907465247749 

我使用了一个程序,计算浮点数为0.1步到600000.我试图测试JVM处理浮点数的性能。

OpenJDK:257ms
OracleJDK:151ms

0.1步到1200000:

OpenJDK:457ms
OracleJDK:263ms

public class Testing {

    /**
     * @param args
     */
    public static long Test()
    {
        float counter=0.0f;
        long startTime = System.currentTimeMillis();
        while (counter <= 1_200_000.0f)
        {
            counter += 0.1f;
        }
        return System.currentTimeMillis() - startTime;
    }

    public static void main(String[] args){
        System.out.println(Test());
    }

}

我尝试了SlipperySeal中提到的增强功能,并将测试放入循环中。我也尝试使用c2编译器,但结果没有区别。

2 个答案:

答案 0 :(得分:16)

OpenJDK Zero VM只是一个解释器JVM。一方面,端口更容易,因为它没有特定于体系结构的汇编代码,但另一方面,它没有高性能,因为它没有特定于体系结构的汇编代码。

OracleJDK利用平台的浮点ABI(RP1上的Soft Float和RP2上的Hard Float)。我可以想象它有相当多的汇编代码,特定于ARM架构,这就是它得分更好的原因。

早期在OpenJDK Zero VM中引入了基于LLVM的名为Shark的JIT编译器。我不确定你的系统的OpenJDK是否是用Shark构建的,但它可能是。它提供了在没有汇编代码和仍然运行高效的本机代码之间的折衷。如果未启用Shark,则在启用Shark的情况下构建IcedTea将提高性能。如果启用了Shark,那么这就是为什么OpenJDK不会吮吸的原因。

答案 1 :(得分:8)

2018年4月的更新。

我使用Raspbian Stretch在Raspberry Pi 3上运行Java Whetstone离线基准测试。可以在文件Raspberry_Pi_Benchmarks/java/source code/whetstone-off-line/whetstc.java中找到源代码here

结论是openjdk-9-jre比openjdk-8-jre(测试版本1.8.0_162)快,后者比oracle-java8-jdk(测试版本1.8.0_65)更快。另请注意,我使用了oracle-java8-jdk的旧内核。

来自Raspbian回购的

openjdk-9-jdk

$ java -version
openjdk version "9-Raspbian"
OpenJDK Runtime Environment (build 9-Raspbian+0-9b181-4bpo9rpt1)
OpenJDK Server VM (build 9-Raspbian+0-9b181-4bpo9rpt1, mixed mode)

$ java whetstc 
   Whetstone Benchmark Java Version, apr. 26 2018, 23:15:40

                                                     1 Pass
Test                  Result       MFLOPS     MOPS  millisecs

N1 floating point  -1,124750137    333,22             0,0576
N2 floating point  -1,131330490    293,19             0,4584
N3 if then else     1,000000000             185,95    0,5566
N4 fixed point     12,000000000             412,95    0,7628
N5 sin,cos etc.     0,499110132              22,40    3,7140
N6 floating point   0,999999821    212,70             2,5360
N7 assignments      3,000000000             105,66    1,7490
N8 exp,sqrt etc.    0,825148463              16,70    2,2280

MWIPS                              829,02            12,0624

Operating System    Linux, Arch. arm, Version 4.14.34-v7+
Java Vendor         Oracle Corporation, Version  9-Raspbian
CPU null
来自Raspbian回购的

openjdk-8-jdk

$ java -version
openjdk version "1.8.0_162"
OpenJDK Runtime Environment (build 1.8.0_162-8u162-b12-1~deb9u1-b12)
OpenJDK Client VM (build 25.162-b12, mixed mode)

$ java whetstc
   Whetstone Benchmark Java Version, Apr 27 2018, 13:13:26

                                                     1 Pass
Test                  Result       MFLOPS     MOPS  millisecs

N1 floating point  -1.124750137    181.82             0.1056
N2 floating point  -1.131330490    175.92             0.7640
N3 if then else     1.000000000              88.61    1.1680
N4 fixed point     12.000000000             389.85    0.8080
N5 sin,cos etc.     0.499110132               9.35    8.8980
N6 floating point   0.999999821     76.27             7.0720
N7 assignments      3.000000000             275.82    0.6700
N8 exp,sqrt etc.    0.825148463               7.15    5.2060

MWIPS                              405.00            24.6916

Operating System    Linux, Arch. arm, Version 4.14.34-v7+
Java Vendor         Oracle Corporation, Version  1.8.0_162
CPU null
来自Raspbian repos的

oracle-java8-jdk

$ java -version
java version "1.8.0_65"
Java(TM) SE Runtime Environment (build 1.8.0_65-b17)
Java HotSpot(TM) Client VM (build 25.65-b01, mixed mode)`

$ java whetstc
   Whetstone Benchmark Java Version, Nov 15 2017, 11:16:37

                                                     1 Pass
Test                  Result       MFLOPS     MOPS  millisecs

N1 floating point  -1.124750137     91.52             0.2098
N2 floating point  -1.131330490     89.01             1.5100
N3 if then else     1.000000000              44.27    2.3380
N4 fixed point     12.000000000             229.76    1.3710
N5 sin,cos etc.     0.499110103               3.01   27.6400
N6 floating point   0.999999821     44.95            12.0000
N7 assignments      3.000000000             137.09    1.3480
N8 exp,sqrt etc.    0.751108646               0.58   63.9100

MWIPS                               90.64           110.3268

Operating System    Linux, Arch. arm, Version 4.9.35-v7+
Java Vendor         Oracle Corporation, Version  1.8.0_65
CPU null