4

我在 googlytubes 上没有看到任何类似答案的东西,所以这里......

我们在 grails 项目中使用了几个本地插件。我们的一个插件最近依赖于 SLF4J。我们的主 webapp(使用插件)也依赖于 SLF4J。这会在运行时产生完全无害但令人恼火的警告:

Error SLF4J: Class path contains multiple SLF4J bindings.

通常我只会在插件 SLF4J 依赖项上定义一个“排除”,但由于这是一个本地插件,我看不到任何方法可以这样做。我试过了...

grails.plugin.location.'localpluginname' = '../localplugindir'

grails.project.dependency.resolution = {
    plugins {
        runtime("com.ourcompany:localpluginname:1.0") {
            excludes('slf4j-api')
        }
    }
}

...但随后它尝试实际解析远程存储库上的所述插件,但失败了。我们也不想直接在插件中排除依赖项,因为该插件可能会在其他尚未提供依赖项的项目中使用。

在有人建议我们将本地插件部署到本地 maven 存储库以执行此操作之前,让我把它从我们不想这样做的方式中解脱出来。我们将它们放在本地是有原因的……所以我们可以快速进行更改并查看所述更改。我们宁愿忍受烦人的警告消息,也不愿增加部署每次更改的痛苦。

4

1 回答 1

0

您收到的警告与类路径中存在多个版本的 slf4j-api 无关。SLF4J API 旨在一次绑定一个且仅一个底层日志框架。如果类路径上存在多个绑定,SLF4J 将发出警告,列出这些绑定的位置。您可以在SLF4J 警告或错误消息及其含义中了解更多信息文档。Slf4J 提出的解决方案是:当类路径上有多个绑定可用时,选择一个且只有一个您希望使用的绑定,并删除其他绑定。在您的情况下,最好的方法是直接从插件中排除 Slf4J 绑定。插件不应依赖于拥有自己的绑定,而是假设 Grails 应用程序将提供绑定(这就是它的作用)

于 2012-11-14T20:40:02.003 回答