2

我用 JMH 测试我的程序性能。并且无法配置堆大小。我想知道为什么它不起作用。

问题:

  1. 为什么 JMH 不接受堆大小配置?
  2. JMH 是否在没有jvmArgs方法的情况下吸收想法堆大小设置?

错误:

# Run progress: 0.00% complete, ETA 00:04:30
# VM invoker: /usr/lib/jvm/java-8-oracle/jre/bin/java
# VM options: -Xms2048m -Xmx2048m -XX:MaxDirectMemorySize=512M
# Fork: 1 of 1
Invalid initial heap size: -Xms2048m -Xmx2048m -XX:MaxDirectMemorySize=512M
Error: Could not create the Java Virtual Machine.
Error: A fatal exception has occurred. Program will exit.
<forked VM failed with exit code 1>

主要方法:

public static void main(String... args) throws RunnerException, IOException {
    Options opt = new OptionsBuilder()
            .include(".*" + ArraySummatorBenchmarking.class.getSimpleName() + ".*")
            .warmupIterations(5)
            .measurementIterations(5)
            .forks(1)
            .jvmArgs("-Xms2048m -Xmx2048m -XX:MaxDirectMemorySize=512M")
            .build();
    new Runner(opt).run();
}

想法.vmoptions

-server
-Xms2056m
-Xmx2056m
-XX:MaxPermSize=1024m
-XX:ReservedCodeCacheSize=256m
-ea
-Dsun.io.useCanonCaches=false
-Djava.net.preferIPv4Stack=true
-Djsse.enableSNIExtension=false
-XX:+UseCodeCacheFlushing
-XX:+UseConcMarkSweepGC
-XX:SoftRefLRUPolicyMSPerMB=50
-Dawt.useSystemAAFontSettings=lcd

主要方法选项:

-Xms2048m -Xmx2048m -XX:MaxDirectMemorySize=512M
4

1 回答 1

8

JMH 使用Runtime.exec(String[])来启动一个分叉的 VM。此方法假定每个数组项有一个命令行标记,并且它将正确地转义标记内的空格。

这意味着当您将"-Xms2048m -Xmx2048m -XX:MaxDirectMemorySize=512M"字符串作为参数传递时,它会被视为单个参数,其中恰好包含空格,而不是三个单独的以空格分隔的参数。

因此,在 JMH 中指定多个 JVM 参数的正确方法是为每个单独的参数使用单独的字符串值:

Options opt = new OptionsBuilder()
        ...
        .jvmArgs("-Xms2048m", "-Xmx2048m", "-XX:MaxDirectMemorySize=512M")
        ...
于 2014-05-27T08:51:36.287 回答