scala - Play 2.3.8 的多个 SLF4J 绑定(bind)

标签 scala playframework sbt aether

我将 Play Framework 2.3.8(用于 Java)与 Scala 2.11 一起使用。

我收到这个警告:

SLF4J: Class path contains multiple SLF4J bindings.
SLF4J: Found binding in [jar:file:/Users/vdanylchuk/.ivy2/cache/org.slf4j/slf4j-simple/jars/slf4j-simple-1.7.7.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Found binding in [jar:file:/Users/vdanylchuk/.ivy2/cache/ch.qos.logback/logback-classic/jars/logback-classic-1.0.13.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation.



这会以随机方式在运行时导致实际问题。在一些已部署的主机上,一切顺利,日志按照配置写入。在其他主机上,错误的绑定(bind)获胜,日志写入错误的位置。部署过程是脚本化的并且完全相同。所以 http://www.slf4j.org/codes.html#multiple_bindings 的警告是正确的,这是随机的,所以我需要删除额外的绑定(bind)。

有趣的是,它们都来自 Play 框架。 logback-classic(我实际上想要使用)来自 play 库,而 slf4j-simple 来自 play sbt 插件。

我在这里和邮件列表中阅读了很多类似的问题。例子:
How to fix "SLF4J: Class path contains multiple SLF4J bindings" at startup of Play 2.3.x?
常见的解决方案是使用某种形式的排除规则。建议的解决方案都不适合我。 [更新:事实上,他们确实这样做了——请参阅下面的解决方案。] 我不希望 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 相同。

最佳答案

我的错。最后,project/plugins.sbt 中的一个简单排除解决了这个问题:

addSbtPlugin("com.typesafe.play" % "sbt-plugin" % "2.3.8" exclude("org.slf4j", "slf4j-simple"))

我之前尝试过,但显然犯了语法错误,并认为这不受支持。掌心

关于scala - Play 2.3.8 的多个 SLF4J 绑定(bind),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29647669/

相关文章:

scala spec2 我无法创建同时使用 must be_== 和 failure 的测试

java - 无法在 Play Framework 中获取路线对象来显示我的自定义路线

scala - 更改 sbt 任务中的设置

scala - 抑制 sbt 控制台/Scala REPL 中的返回类型

node.js - TypeError : jsdom. createVirtualConsole 不是函数

Scala:从嵌套案例类到展平案例类

scala - 当 PUT 上的查询参数类型错误时,Spray 以错误的原因拒绝了我的请求(405 但应该是 400)

java - 部署到 Heroku 时找不到 Play Framework 2.3.6 (Java) javascript 和样式表

scala - 这个 Controller Instantiation 异常是什么意思?

scala - SBT 准备 WAR 文件,重复条目 : META-INF/MANIFEST. MF