java - sbt 运行正常但运行 jar 失败

标签 java scala sbt akka akka-http

当我从 sbt 运行时

(sbt run)

我的 akka http 服务运行良好,但是在使用 jar 运行时出现以下错误

(java -jar myservice.jar)

由 publishLocal 创建

(sbt publishLocal)

Exception in thread "main" java.lang.NoClassDefFoundError: org/slf4j/LoggerFactory
    at com.rogers.profileauthn.StartProfileAuthService.<clinit>(StartProfileAuthService.java:15)
Caused by: java.lang.ClassNotFoundException: org.slf4j.LoggerFactory
    at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:335)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)

sbt文件中的依赖如下

val akkaVersion = "2.5.11"
val akkaHttpVersion = "10.0.11"
libraryDependencies ++= Seq(
  "ch.qos.logback" % "logback-classic" % "1.2.3",
  "com.typesafe.akka" %% "akka-http"            % akkaHttpVersion,
  "com.typesafe.akka" %% "akka-stream"          % akkaVersion,
  "com.typesafe.akka" %% "akka-http-jackson"    % akkaHttpVersion,
  "com.typesafe.akka" %% "akka-http-testkit" % akkaHttpVersion % Test,
  "com.typesafe.akka" %% "akka-testkit" % akkaVersion % Test,
  "junit"              % "junit"             % "4.12"          % Test,
  "com.novocode"       % "junit-interface"   % "0.10"          % Test,
  "com.typesafe.play" %% "play-json" % "2.6.9",
  "com.github.swagger-akka-http" %% "swagger-akka-http" % "0.11.0",
  "com.google.inject" % "guice" % "4.1.0",
  "com.google.guava" % "guava" % "18.0",
  "org.mockito" % "mockito-core" % "2.11.0"

)

下面是我正在使用的记录器

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
...
private static final Logger LOGGER = LoggerFactory.getLogger(StartService.class);
    LOGGER.info("**** StartService.createAndStartActorSystem Starts ****");

最佳答案

我认为那是因为 jar 没有与您的依赖项一起打包。你能尝试用 sbt assembly 创建一个 fat jar 吗? https://github.com/sbt/sbt-assembly . publishLocal 命令用于部署到 ivy 存储库,而不是创建 jar 来像我相信的那样运行。 (添加插件并运行 sbt 程序集)

关于java - sbt 运行正常但运行 jar 失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49826486/

相关文章:

scala - 在 X/未解析(传递)依赖项中找不到新的 sbt "feature"配置

java - 通过谷歌云端点通过 Android 客户端将文件上传到谷歌云存储

scala - 比较 Seq 和 Array 的不同行为

scala - 如何通过 Scala 插件在 IntelliJ CE 中使用 Scala 工作表中的类?

json - 将 Json 转换为 Map[String, String]

scala - 包含 Spark Streaming Kinesis ASL 库时 Spark 作业 SBT 程序集合并冲突

java - 如何让 ATG Droplet 提供默认的 oparam

java - 使用 MySQL DB 中的一些数据填充 Swing 表

java - 如何以每个单元格包含由两行组成的 `String` 的方式填充 JTable?

scala - build.sbt 和 build.scala 有什么区别?