【发布时间】:2014-11-12 07:55:34
【问题描述】:
我正在使用 maven
我添加了以下依赖项
<dependency> <!-- Spark dependency -->
<groupId>org.apache.spark</groupId>
<artifactId>spark-streaming_2.10</artifactId>
<version>1.1.0</version>
</dependency> <dependency> <!-- Spark dependency -->
<groupId>org.apache.spark</groupId>
<artifactId>spark-streaming-kafka_2.10</artifactId>
<version>1.1.0</version>
</dependency>
我在代码中也添加了jar
SparkConf sparkConf = new SparkConf().setAppName("KafkaSparkTest");
JavaSparkContext sc = new JavaSparkContext(sparkConf);
sc.addJar("/home/test/.m2/repository/org/apache/spark/spark-streaming-kafka_2.10/1.0.2/spark-streaming-kafka_2.10-1.0.2.jar");
JavaStreamingContext jssc = new JavaStreamingContext(sc, new Duration(5000));
它可以很好地完成,没有任何错误,当我运行 spark-submit 时出现以下错误,非常感谢任何帮助。感谢您的宝贵时间。
bin/spark-submit --class "KafkaSparkStreaming" --master local[4] try/simple-project/target/simple-project-1.0.jar
线程“主”java.lang.NoClassDefFoundError 中的异常:org/apache/spark/streaming/kafka/KafkaUtils 在 KafkaSparkStreaming.sparkStreamingTest(KafkaSparkStreaming.java:40) 在 KafkaSparkStreaming.main(KafkaSparkStreaming.java:23) 在 sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 在 sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 在 sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 在 java.lang.reflect.Method.invoke(Method.java:606) 在 org.apache.spark.deploy.SparkSubmit$.launch(SparkSubmit.scala:303) 在 org.apache.spark.deploy.SparkSubmit$.main(SparkSubmit.scala:55) 在 org.apache.spark.deploy.SparkSubmit.main(SparkSubmit.scala) 引起:java.lang.ClassNotFoundException:org.apache.spark.streaming.kafka.KafkaUtils 在 java.net.URLClassLoader$1.run(URLClassLoader.java:366)
【问题讨论】:
-
您的 addJar 方法不是必需的。但是,您应该在包含依赖项的 .jar 中添加 maven 程序集插件和包(不要找到 spark-kafka 依赖项)。
-
我在 pom 的依赖列表中添加了 spark-streaming-kafka_2.10
-
感谢添加 maven 程序集插件帮助..
标签: java maven apache-spark apache-kafka