2016-06-18 3 views
2

У меня есть много времени, пытаясь настроить искру на Intellij на моей локальной машине.Настройка Spark на IntelliJ за вклад в Spark

Цель: запустить SparkPi.scala без каких-либо ошибок.

шаги:

git clone `https://github.com/apache/spark` 
Import the project to Intellij as a Maven Project 
build/mvn -DskipTests clean package 
navigate to examples folder modify pom.xml (change occurrences of provided , test -> compile) 
Open SparkPi.scala and add `.master("local[4]")` to Spark Session 
Right click and run SparkPi 

Ошибка я столкнулся с

Exception in thread "main" java.lang.NoClassDefFoundError: com/google/common/collect/MapMaker 
    at org.apache.spark.SparkContext.<init>(SparkContext.scala:271) 
    at org.apache.spark.SparkContext$.getOrCreate(SparkContext.scala:2257) 
    at org.apache.spark.sql.SparkSession$Builder$$anonfun$8.apply(SparkSession.scala:822) 
    at org.apache.spark.sql.SparkSession$Builder$$anonfun$8.apply(SparkSession.scala:814) 
    at scala.Option.getOrElse(Option.scala:121) 
    at org.apache.spark.sql.SparkSession$Builder.getOrCreate(SparkSession.scala:814) 
    at org.apache.spark.examples.SparkPi$.main(SparkPi.scala:31) 
    at org.apache.spark.examples.SparkPi.main(SparkPi.scala) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:483) 
    at com.intellij.rt.execution.application.AppMain.main(AppMain.java:144) 
Caused by: java.lang.ClassNotFoundException: com.google.common.collect.MapMaker 
    at java.net.URLClassLoader$1.run(URLClassLoader.java:372) 
    at java.net.URLClassLoader$1.run(URLClassLoader.java:361) 
    at java.security.AccessController.doPrivileged(Native Method) 
    at java.net.URLClassLoader.findClass(URLClassLoader.java:360) 
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424) 
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308) 
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357) 
    ... 13 more 

ответ

1

Вы должны rebuild проект под Intellij. Грустно, но верно: IJ не может просто повторно использовать встроенную инфраструктуру maven.

Однако он использует часть из командной строки mvn Структура: вам нужно сначала запустить mvn.

Категория: google MapMaker Тип: означает, что зависимости не загружаются должным образом и не доступны. Это необходимо решить после полной перестройки.

+0

Как я могу перестроить? Пример будет полезен. –

+0

@KrishnaKalyan Я просто ссылаюсь на «Проект | Переустановить "из главного меню. – javadba

Смежные вопросы