java - 在 Eclipse Maven 项目中使用 sl4j 配置 Logback

标签 java eclipse maven slf4j logback

我有一个 eclipse maven 项目,我尝试在其中使用 logback.xml。但是 logback.xml 没有被选中。我经历过这个link并已验证 logback.xml 是否放置在 src/main/resources/ 中,并且位于我的类路径中。

我的logback.xml如下所示:-

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
  <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
    <encoder>
      <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern> 
    </encoder>
  </appender>
  <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
      <!-- Daily rollover -->
      <fileNamePattern>/tmp/SolrUpdater.%d{yyyy-MM-dd}.log</fileNamePattern>
      <!-- Keep 7 days' worth of history -->
      <maxHistory>7</maxHistory>
    </rollingPolicy>
    <encoder>
      <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
    </encoder>
  </appender>
  <root>
    <level value="INFO" />
    <appender-ref ref="CONSOLE" />
    <appender-ref ref="FILE" />
  </root>
</configuration>

Maven 依赖项如下所示:-

<?xml version="1.0" encoding="UTF-8"?>
<dependencies>
  <dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-api</artifactId>
    <version>1.7.13</version>
  </dependency>
  <dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-jdk14</artifactId>
    <version>1.7.13</version>
  </dependency>
  <dependency>
    <groupId>org.apache.solr</groupId>
    <artifactId>solr-solrj</artifactId>
    <version>5.2.1</version>
  </dependency>
  <dependency>
    <groupId>commons-logging</groupId>
    <artifactId>commons-logging</artifactId>
    <version>1.2</version>
  </dependency>
  <dependency>
    <groupId>ch.qos.logback</groupId>
    <artifactId>logback-classic</artifactId>
    <version>1.0.13</version>
  </dependency>
  <dependency>
    <groupId>ch.qos.logback</groupId>
    <artifactId>logback-core</artifactId>
    <version>1.0.13</version>
  </dependency>
</dependencies>

我还验证了 src/main/resource 在 Eclipse 中被标记为资源目录,如下所示:- enter image description here

有人可以告诉我出了什么问题吗?

最佳答案

您不能同时使用两个日志记录后端。您应该会看到有关类路径上多个 SLF4J 实现的运行时警告。

在依赖项列表中,

slf4j-jdk14 位于 logback-classic 之前,因此所有日志消息都会路由到 java.util.logging 后端,并且您的 Logback 配置根本没有任何作用。

删除 slf4j-jdk14 依赖项,并确保您没有任何其他 SLF4J 后端作为传递依赖项。

关于java - 在 Eclipse Maven 项目中使用 sl4j 配置 Logback,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33844702/

相关文章:

java - 漂亮的 HTML 片段输出

java - 上传包错误

java - 如何在 eclipse rcp 应用程序中启用上下文相关帮助?

eclipse:不显示调用层次结构中二进制类型的引用

java - 如何使用 Spring Boot 构建两个重新打包的 jar

java - 找到类 org.apache.hadoop.mapreduce.TaskInputOutputContext,但应为接口(interface)

java - 我应该创建额外的配置模型还是可以直接使用 Properties 对象?

java - java中的多线程

java - 我们可以在 pojo 中放置两个 setter 吗?

java - Maven + Jersey RESTful API : Internal Server Error from POSTMAN on GET request