Flink错误:找不到或加载主类

时间:2018-06-21 16:29:06

标签: maven apache-flink jmh

我正在尝试运行那些Flink基准测试: https://github.com/dataArtisans/flink-benchmarks

我已经使用maven通过以下命令生成了jar文件:

mvn clean package -Pbuild-jar

然后,我尝试使用该命令在Flink群集上运行基准测试:

./bin/flink run -c org.apache.flink.benchmark.WindowBenchmarks ~/flinkBenchmarks/target/flink-hackathon-benchmarks-0.1.jar

我已经使用-c选项将要运行的基准测试Main(WindowBenchmarks)添加到类路径中。

最后,我得到了这个错误:

# JMH version: 1.19
# VM version: JDK 1.8.0_151, VM 25.151-b12
# VM invoker: /usr/lib/jvm/java-8-oracle/jre/bin/java
# VM options: -Dlog.file=/home/user/flink-1.3.2/flink-dist/target/flink-1.3.2-bin/flink-1.3.2/log/flink-user-client-mypc.log -Dlog4j.configuration=file:/home/user/flink-1.3.2/flink-dist/target/flink-1.3.2-bin/flink-1.3.2/conf/log4j-cli.properties -Dlogback.configurationFile=file:/home/user/flink-1.3.2/flink-dist/target/flink-1.3.2-bin/flink-1.3.2/conf/logback.xml -Djava.rmi.server.hostname=127.0.0.1 -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false
# Warmup: 10 iterations, 1 s each
# Measurement: 10 iterations, 1 s each
# Timeout: 10 min per iteration
# Threads: 1 thread, will synchronize iterations
# Benchmark mode: Throughput, ops/time
# Benchmark: org.apache.flink.benchmark.WindowBenchmarks.sessionWindow

# Run progress: 0.00% complete, ETA 00:04:00
# Fork: 1 of 3
Error: Could not find or load main class org.openjdk.jmh.runner.ForkedMain
<forked VM failed with exit code 1>
<stdout last='20 lines'>
</stdout>
<stderr last='20 lines'>
Error: Could not find or load main class org.openjdk.jmh.runner.ForkedMain
</stderr>

# Run complete. Total time: 00:00:00

Benchmark  Mode  Cnt  Score   Error  Units

The program didn't contain a Flink job. Perhaps you forgot to call execute() on the execution environment.

我以前没有使用Flink和Maven的经验,所以我找出了缺失的地方。我的第一个想法是这是一个缺少的依赖项错误,但是看起来不错。有什么建议吗?

提前谢谢!

1 个答案:

答案 0 :(得分:3)

flink-benchmarks是一个存储库,其中包含一组微基准测试,这些基准旨在在单机而不是集群上运行。在各个类(测试用例)中定义的main函数是“ JMH”运行程序,而不是Flink程序。因此,您可以执行整个基准测试套件(大约需要1个小时):

mvn -Dflink.version=1.5.0 clean install exec:exec

或者如果您只想执行一个基准测试,最好的方法是手动执行选定的主要功能。例如,从您的IDE(不要忘记选择flink.version,该属性的默认值在pom.xml中定义)。

也有a possibility to execute single benchmark from console,但很长一段时间我都没有尝试过。