我收到以下错误:
Py4JError(u'调用 o73.createDirectStreamWithoutMessageHandler 时发生错误。Trace:\npy4j.Py4JException: Method createDirectStreamWithoutMessageHandler([class org.apache.spark.streaming.api.java.JavaStreamingContext, class java.util.HashMap, class java.util .HashSet,类 java.util.HashMap]) 不存在\n\tat py4j.reflection.ReflectionEngine.getMethod(ReflectionEngine.java:335)\n\tat py4j.reflection.ReflectionEngine.getMethod(ReflectionEngine.java:344) \n\tat py4j.Gateway.invoke(Gateway.java:252)\n\tat py4j.commands.AbstractCommand.invokeMethod(AbstractCommand.java:133)\n\tat py4j.commands.CallCommand.execute(CallCommand.java: 79)\n\tat py4j.GatewayConnection.run(GatewayConnection.java:209)\n\tat java.lang.Thread.run(Thread.java:745)\n\n',)
我正在使用 spark-streaming-kafka-assembly_2.10-1.6.0.jar (它存在于我所有节点 + 主节点上的 /usr/lib/hadoop/lib/ 文件夹中)
(编辑)实际错误是: java.lang.NoSuchMethodError: org.apache.hadoop.yarn.util.Apps.crossPlatformify(Ljava/lang/String;)Ljava/lang/String;
这是由于错误的 hadoop 版本。因此 spark 应该使用正确的 hadoop 版本编译:
mvn -Phadoop-2.6 -Dhadoop.version=2.7.2 -DskipTests clean package
这将在 external/kafka-assembly/target 文件夹中生成一个 jar。