Zeppelin: java.lang.NoClassDefFoundError: org / apache / spark / Ведение журнала - PullRequest
0 голосов
/ 30 мая 2018

Я пытаюсь найти трендовые хэштеги в твиттере, используя потоковую передачу Spark.

os -> mac os

spark-version -> 2.2.1

scala-версия -> 2.11.8

zeppelin-версия -> 0.7.3

Выше я использую инструменты и версии.Я добавил три разных банки в мой блокнот zeppelin:

twitter4j-core-4.0.4.jar

twitter4j-stream-4.0.4.jar

spark-streaming-twitter_2.10-1.0.0.jar

import org.apache.spark._
import org.apache.spark.SparkContext._
import org.apache.spark.streaming._
import org.apache.spark.streaming.twitter._
import org.apache.spark.streaming.StreamingContext._

def setUpTwitter() = {
    import scala.io.Source
    for (line <- Source.fromFile("/Users/abhijeet/Documents/sparkscala/SparkScala/twitter.txt").getLines) {
        val fields = line.split(" ")
        if (fields.length == 2){
            System.setProperty("twitter4j.oauth." + fields(0), fields(1))
        }
    }
}
setUpTwitter()
val ssc = new StreamingContext(sc, Seconds(1))
def setupLogging() = {
    import org.apache.log4j.{Level, Logger}
    val rootLogger = Logger.getRootLogger()
    rootLogger.setLevel(Level.ERROR)
}
setupLogging()

До этого момента в коде zeppelin работал нормально

val tweets = TwitterUtils.createStream(ssc, None)

In вышестрока начала выдавать ошибку

java.lang.NoClassDefFoundError: org/apache/spark/Logging
  at java.lang.ClassLoader.defineClass1(Native Method)
  at java.lang.ClassLoader.defineClass(ClassLoader.java:763)
  at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
  at java.net.URLClassLoader.defineClass(URLClassLoader.java:467)
  at java.net.URLClassLoader.access$100(URLClassLoader.java:73)
  at java.net.URLClassLoader$1.run(URLClassLoader.java:368)
  at java.net.URLClassLoader$1.run(URLClassLoader.java:362)
  at java.security.AccessController.doPrivileged(Native Method)
  at java.net.URLClassLoader.findClass(URLClassLoader.java:361)
  at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
  at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:338)
  at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
  at org.apache.spark.streaming.twitter.TwitterUtils$.createStream(TwitterUtils.scala:44)
  ... 56 elided
Caused by: java.lang.ClassNotFoundException: org.apache.spark.Logging
  at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
  at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
  at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:338)
  at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
  ... 69 more

После этого я обнаружил, что org.apache.spark.Logging доступен в Spark версии 1.5.2 или ниже.Это не в 2.0.0.

Меня беспокоит то, что я использую Zeppelin.У меня нет файла pom или чего-либо другого для изменения версии.

Как решить эту ошибку?

Любая помощь будет принята с благодарностью!

Спасибо

1 Ответ

0 голосов
/ 30 мая 2018

Я нашел решение, добавив jar

spark-core_2.11-1.5.2.logging.jar

...