2016-10-03 2 views
0

간단한 카프카 스파크 스트리밍 예제를 실행하려고합니다. 여기에 내가 얻는 오류가있다.간단한 스파크 스트리밍 카프카 예제를 실행하는 중에 오류가 발생했습니다.

16/10/02 20:45:43 INFO SparkEnv: Registering OutputCommitCoordinator Exception in thread "main" java.lang.NoSuchMethodError: scala.Predef$.$scope()Lscala/xml/TopScope$; at org.apache.spark.ui.jobs.StagePage.(StagePage.scala:44) at org.apache.spark.ui.jobs.StagesTab.(StagesTab.scala:34) at org.apache.spark.ui.SparkUI.(SparkUI.scala:62) at org.apache.spark.ui.SparkUI$.create(SparkUI.scala:215) at org.apache.spark.ui.SparkUI$.createLiveUI(SparkUI.scala:157) at org.apache.spark.SparkContext.(SparkContext.scala:443) at org.apache.spark.streaming.StreamingContext$.createNewSparkContext(StreamingContext.scala:836) at org.apache.spark.streaming.StreamingContext.(StreamingContext.scala:84) at org.apache.spark.streaming.api.java.JavaStreamingContext.(JavaStreamingContext.scala:138) at com.application.SparkConsumer.App.main(App.java:27)

이 예제는 다음과 같이 설정합니다. 이 누락 된 scala.Predef 클래스를 찾으려고 시도하고 spark-streaming-kafka-0-8 어셈블리에 대한 누락 된 종속성을 추가했으며이 병을 탐색 할 때 클래스를 볼 수 있습니다.

<dependency> 
    <groupId>org.apache.kafka</groupId> 
    <artifactId>kafka_2.11</artifactId> 
    <version>0.8.2.0</version> 
</dependency> 
<dependency> 
    <groupId>org.apache.kafka</groupId> 
    <artifactId>kafka-clients</artifactId> 
    <version>0.8.2.0</version> 
</dependency> 
<dependency> 
     <groupId>org.apache.spark</groupId> 
     <artifactId>spark-core_2.11</artifactId> 
     <version>2.0.0</version> 
     <scope>provided</scope> 
</dependency> 
<dependency> 
     <groupId>org.apache.spark</groupId> 
     <artifactId>spark-streaming_2.11</artifactId> 
     <version>2.0.0</version> 
     <scope>provided</scope> 
</dependency> 
<dependency> 
    <groupId>org.apache.spark</groupId> 
    <artifactId>spark-streaming-kafka-0-8_2.11</artifactId> 
    <version>2.0.0</version> 
</dependency> 
<dependency> 
    <groupId>org.scala-lang</groupId> 
    <artifactId>scala-library</artifactId> 
    <version>2.11.0</version> 
</dependency> 
<dependency> 
    <groupId>org.apache.spark</groupId> 
    <artifactId>spark-streaming-kafka-0-8-assembly_2.11</artifactId> 
    <version>2.0.0</version> 
</dependency> 

간단한 스파크 단어 집계 예제를 시도했지만 정상적으로 작동합니다. 이 spark-streaming-kafka를 사용할 때 문제가 있습니다. 이 오류를 찾으려고 노력했지만 행운이 없습니다.

다음은 코드 단편입니다.

 SparkConf sparkConf = new SparkConf().setAppName("someapp").setMaster("local[2]"); 
     // Create the context with 2 seconds batch size 
     JavaStreamingContext jssc = new JavaStreamingContext(sparkConf, new Duration(2000)); 

     int numThreads = Integer.parseInt(args[3]); 
     Map<String, Integer> topicMap = new HashMap<String,Integer>(); 
     topicMap.put("fast-messages", 1); 
     Map<String, String> kafkaParams = new HashMap<String,String>(); 
     kafkaParams.put("metadata.broker.list", "localhost:9092"); 
     JavaPairReceiverInputDStream<String, String> messages = 
     KafkaUtils.createStream(jssc,"zoo1","my-consumer-group", topicMap); 

답변

0

0.8.2.0 카프카 2.11을 사용했을 때 문제가있는 것 같습니다. 2.10으로 전환 한 후 제대로 작동했습니다.

관련 문제