我将 Play Framework 2.3.8(用于 Java)与 Scala 2.11 一起使用。
我收到这个警告:
SLF4J:类路径包含多个 SLF4J 绑定。
SLF4J:在 [jar:file:/Users/vdanylchuk/.ivy2/cache/org.slf4j/slf4j-simple/jars/slf4j-simple-1.7.7.jar!/org/slf4j/impl/StaticLoggerBinder.class 中找到绑定]
SLF4J:在 [jar:file:/Users/vdanylchuk/.ivy2/cache/ch.qos.logback/logback-classic/jars/logback-classic-1.0.13.jar!/org/slf4j/impl/ 中找到绑定StaticLoggerBinder.class]
SLF4J:有关说明,请参见http://www.slf4j.org/codes.html#multiple_bindings。
这会以随机方式在运行时导致实际问题。在一些已部署的主机上,一切顺利,日志按照配置写入。在其他主机上,错误的绑定获胜,日志写入错误的位置。部署过程是脚本化的并且完全相同。所以http://www.slf4j.org/codes.html#multiple_bindings上的警告是正确的,这是随机的,所以我需要删除额外的绑定。
有趣的是,它们都来自 Play 框架。logback-classic(我实际上想要使用)来自 play 库,而 slf4j-simple 来自 play sbt 插件。
我在这里和邮件列表中阅读了很多类似的问题。示例: 如何在 Play 2.3.x 启动时修复“SLF4J:类路径包含多个 SLF4J 绑定”? 常见的解决方案是使用某种形式的排除规则。建议的解决方案都不适合我。[更新:事实上,他们确实这样做了 - 请参阅下面的解决方案。] 我不希望 slf4j-simple 出现在最终的类路径中,但确实如此。即使我将 excludeAll(ExclusionRule(organization = "org.slf4j")) 添加到项目中的每个依赖项中,除了 play 框架。
关于如何摆脱 slf4j-simple 的任何想法?最好在 sbt 项目级别上,无需手动清理构建结果的类路径。
更新:复制说明
我用一个小测试项目缩小了范围。原来它是由 play sbt 插件和我们使用的 aether-deploy 插件的组合触发的。有这个小配置就足够了。
构建.sbt:
name := "slf4j-test"
version := "1.0"
scalaVersion := "2.11.5"
lazy val root = (project in file(".")).enablePlugins(PlayJava)
项目/plugins.sbt:
resolvers += "Typesafe repository" at "http://repo.typesafe.com/typesafe/releases/"
addSbtPlugin("com.typesafe.play" % "sbt-plugin" % "2.3.8")
addSbtPlugin("no.arktekk.sbt" % "aether-deploy" % "0.13")
项目/build.properties:
sbt.version=0.13.7
然后只需运行“sbt test:compile”或“sbt run”(并查询 localhost:9000)即可查看警告。它与 scala 2.10 相同。