web-dev-qa-db-ja.com

Spark2.2.1互換性のないJacksonバージョン2.8.8

私の構成は次のとおりです。

  • Scala 2.11(プラグインScala IDE)
  • Eclipse Neon.3リリース(4.6.3)
  • Windows 7 64ビット

このシンプルなscalaコード(Esempio.scala)を実行したい:

package it.scala

// importo packages di Spark
import org.Apache.spark.SparkContext
import org.Apache.spark.SparkConf


object Wordcount {
    def main(args: Array[String]) {

        val inputs: Array[String] = new Array[String](2)
        inputs(0) = "C:\\Users\\FobiDell\\Desktop\\input"
        inputs(1) = "C:\\Users\\FobiDell\\Desktop\\output"

        // oggetto SparkConf per settare i parametri sulla propria applicazione 
        // da fornire poi al cluster manager scelto (Yarn, Mesos o Standalone).
        val conf = new SparkConf()
        conf.setAppName("Smartphone Addiction")
        conf.setMaster("local")

        // oggetto SparkContext per connessione al cluster manager scelto
        val sc = new SparkContext(conf)

        //Read file and create RDD
        val rawData = sc.textFile(inputs(0))

        //convert the lines into words using flatMap operation
        val words = rawData.flatMap(line => line.split(" "))

        //count the individual words using map and reduceByKey operation
        val wordCount = words.map(Word => (Word, 1)).reduceByKey(_ + _)

        //Save the result
        wordCount.saveAsTextFile(inputs(1))

       //stop the spark context
       sc.stop

   }

}

したがって、Spark-Shellを使用すると、Eclipse IDEからファイル(Esempio.scala)を選択し、Run-> Run as-> Scalaアプリケーションを介して実行すると、すべてがOKです。

Exception in thread "main" Java.lang.ExceptionInInitializerError
    at org.Apache.spark.SparkContext.withScope(SparkContext.scala:701)
    at org.Apache.spark.SparkContext.textFile(SparkContext.scala:830)
    at it.scala.Wordcount$.main(Esempio.scala:47)
    at it.scala.Wordcount.main(Esempio.scala)
Caused by: com.fasterxml.jackson.databind.JsonMappingException: Incompatible Jackson version: 2.8.8
    at com.fasterxml.jackson.module.scala.JacksonModule$class.setupModule(JacksonModule.scala:64)
    at com.fasterxml.jackson.module.scala.DefaultScalaModule.setupModule(DefaultScalaModule.scala:19)
    at com.fasterxml.jackson.databind.ObjectMapper.registerModule(ObjectMapper.Java:745)
    at org.Apache.spark.rdd.RDDOperationScope$.<init>(RDDOperationScope.scala:82)
    at org.Apache.spark.rdd.RDDOperationScope$.<clinit>(RDDOperationScope.scala)
    ... 4 more  

私のpom.xmlファイルは次のとおりです。

<project xmlns="http://maven.Apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.Apache.org/POM/4.0.0 http://maven.Apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>

  <groupId>it.hgfhgf.xhgfghf</groupId>
  <artifactId>progetto</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <packaging>jar</packaging>

  <name>progetto</name>
  <url>http://maven.Apache.org</url>

  <properties>
     <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  </properties>

  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>3.8.1</version>
      <scope>test</scope>
    </dependency>

    <!-- Neo4j JDBC DRIVER -->
    <dependency>
      <groupId>org.neo4j</groupId>
      <artifactId>neo4j-jdbc-driver</artifactId>
      <version>3.1.0</version>
    </dependency>

    <!-- Scala -->
    <dependency>
      <groupId>org.scala-lang</groupId>
      <artifactId>scala-library</artifactId>
      <version>2.11.11</version>
    </dependency> 

    <!-- Spark -->
    <dependency>
      <groupId>org.Apache.spark</groupId>
      <artifactId>spark-core_2.11</artifactId>
      <version>2.2.1</version>
    </dependency>


  </dependencies>


</project>

Spark-2.2.1-bin-hadoop2.7/jarsディレクトリにある.jarファイルは次のとおりであることに気付きました。

  • jackson-core-2.6.5.jar
  • jackson-databind-2.6.5.jar
  • jackson-module-paranamer-2.6.5.jar
  • jackson-module-scala_2.11-2.6.5.jar
  • jackson-annotations-2.6.5.jar

誰もがこの例外が何であり、どのように解決できるかを簡単な言葉で説明できますか?

7
Fobi

Spark 2.xにはjackson 2.6.5が含まれ、neo4j-jdbc-driverjackson 2.8.8バージョンを使用します。ここでは、2つの異なるバージョンのjacksonライブラリ間の依存関係の競合があります。そのため、このIncompatible Jackson version: 2.8.8エラーが発生します。

pom.xml内のこれらの[以下]モジュールの依存関係バージョンをオーバーライドして、動作するかどうかを確認してください。

  1. ジャクソンコア
  2. jackson-databind
  3. jackson-module-scala_2.x

または、pom.xmlに以下の依存関係を追加してみてください

        <dependency>
            <groupId>com.fasterxml.jackson.module</groupId>
            <artifactId>jackson-module-scala_2.11</artifactId>
            <version>2.8.8</version>
        </dependency> 
20
subodh

私はジャクソンの同じバージョンの競合に遭遇しました。 jackson-core、jackson-databind、jackson-module-scala_2.xをオーバーライドすることに加えて、pom.xmlでjackson-annotationsを定義して、競合を解決しました。

2
Lorenz Bernauer

Scalaバージョン2.1.1はJackson 2.6.5で動作します。以下を使用してください。

    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-databind</artifactId>
        <version>2.6.5</version>
    </dependency>
1
David Urry
Below is the combination that worked for me .

 aws-Java-sdk-1.7.4.jar
 hadoop-aws-2.7.3.jar
 joda-time-2.9.6.jar
 hadoop-client-2.7.3-sources.jar
 hadoop-client-2.7.3.jar
 hadoop-client-2.6.0-javadoc.jar
 hadoop-client-2.6.0.jar
 jets3t-0.9.4.jar
 jackson-core-2.10.0.jar
 jackson-databind-2.8.6.jar
 jackson-module-scala_2.11-2.8.5.jar
 jackson-annotations-2.8.7.jar
0