Я использую SBT (внутри IntelliJ IDEA) для создания простого проекта Scala.
Я хотел бы знать, что является простейшим способом для создания файла Uber JAR (также называемого Fat JAR, Super JAR).
В настоящее время я использую SBT, но когда я отправляю свой JAR файл в Apache Spark, я получаю следующую ошибку:
Исключение в потоке "main" java.lang.SecurityException: Недействительный сигнатурный дайджест файлов для основных атрибутов
Или эта ошибка во время компиляции:
java.lang.RuntimeException: deduplicate: найдено другое содержимое файла в следующем:
PATH\DEPENDENCY.jar: META-INF/ЗАВИСИМОСТИ
PATH\DEPENDENCY.jar: META-INF/MANIFEST.MF
Он выглядит как, потому что некоторые из моих зависимостей включают файлы подписи (META-INF), которые необходимо удалить в финальном файле Uber JAR.
Я попытался использовать плагин sbt-assembly:
/project/assembly.sbt
addSbtPlugin("com.eed3si9n" % "sbt-assembly" % "0.12.0")
/project/plugins.sbt
logLevel := Level.Warn
/build.sbt
lazy val commonSettings = Seq(
name := "Spark-Test"
version := "1.0"
scalaVersion := "2.11.4"
)
lazy val app = (project in file("app")).
settings(commonSettings: _*).
settings(
libraryDependencies ++= Seq(
"org.apache.spark" %% "spark-core" % "1.2.0",
"org.apache.spark" %% "spark-streaming" % "1.2.0",
"org.apache.spark" % "spark-streaming-twitter_2.10" % "1.2.0"
)
)
Когда я нажимаю "Build Artifact..." в IntelliJ IDEA, я получаю файл JAR. Но в итоге я получаю ту же ошибку...
Я новичок в SBT и не очень экспериментировал с IntelliJ IDE.
Спасибо.