[英]Can not find logback.xml in resources folder
我正在尝试在项目中使用logback,但存在一些问题。 当我运行我的代码时,它给了我这个:
SLF4J: Class path contains multiple SLF4J bindings.
SLF4J: Found binding in [jar:file:/home/mostafa/.m2/repository/org/slf4j/slf4j-log4j12/1.7.2/slf4j-log4j12-1.7.2.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Found binding in [jar:file:/home/mostafa/.m2/repository/ch/qos/logback/logback-classic/1.1.1/logback-classic-1.1.1.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation.
SLF4J: Actual binding is of type [org.slf4j.impl.Log4jLoggerFactory]
log4j:WARN No appenders could be found for logger (com.project.Test).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.
我的logback.xml在resources
文件夹下:
$ tree sample |-- pom.xml `-- src `-- main |-- java | |-- resources | `-- logback.xml
我的项目结构是:
如果您仔细阅读提供的错误消息,您会注意到问题是构建路径上sfl4j的多个绑定。 您包括了sfl4j-log4j和经典的logback工件。 由于logback-classic已经包含sfl4j的本机实现,并且还自动将sfl4j jar添加到您的项目中,因此最终在构建路径中包含多个sf4j。 只需下定决心,仅选择一个日志记录框架,然后从依赖项中删除另一个。
因此,如果选择经典的logback,则Maven依赖项将如下所示:
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.1.1</version>
</dependency>
如果选择log4j,则使其如下所示
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>1.7.2</version>
</dependency>
但不要同时包括两者!
从sfl4j手册 :
如果希望将logback-classic用作基础日志记录框架,则只需在pom.xml文件中将“ ch.qos.logback:logback-classic”声明为依赖项即可,如下所示。 除了logback-classic-1.0.13.jar之外,这还将把slf4j-api-1.7.7.jar以及logback-core-1.0.13.jar拉入您的项目。 请注意,显式声明对logback-core-1.0.13或slf4j-api-1.7.7.jar的依赖关系是正确的,并且可能需要借助Maven的“最近定义”依赖关系中介规则来强加正确版本的工件。
您是否正在使用cassandra或其他可能将log4j工件添加到库中的东西?
如果将cassandra-all工件添加到依赖项,并且由于cassandra将log4j用作自日志记录的SLF4J后端,它将导入slf4j-log4j12.jar
您可以像这样编辑pom.xml:
<dependency>
<groupId>org.apache.cassandra</groupId>
<artifactId>cassandra-all</artifactId>
<version>2.0.5</version>
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
</exclusion>
<exclusion>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
</exclusion>
</exclusions>
</dependency>
另请阅读以下链接:
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.