gpt4 book ai didi

java - spring 和 hibernate 的日志配置

转载 作者:行者123 更新时间:2023-11-30 02:40:46 26 4
gpt4 key购买 nike

目前,我正在与

  • log4j 2.7;
  • springframework 4.3.5;
  • hibernate 5.2.3。

我通过 xml 文件配置 log4j。
为此,我创建了一些附加程序,其中之一名为“General”。我需要的是所有日志都必须发送到该附加程序(包括由 springframework 或 hibernate 生成的日志),并且后者不会打印在控制台上(我仍然需要来自其他类的其他日志)。
我尝试编写这些记录器:

<Loggers>
<Logger name="org" level="ALL" />
<Root level="ALL" additivity="false">
<AppenderRef ref="General"/>
</Root>
<Logger name="tests" level="ALL" additivity="false">
<AppenderRef ref="console"/>
<AppenderRef ref="General"/>
</Logger>
</Loggers>

要点是,虽然除 springframework 之外的所有包都通过该附加程序正确记录,但 springframework 仍然登录到控制台,并且不会通过“常规”附加程序写入任何行。我该如何解决这个问题?

编辑:我发现这可能是由于 springframework 似乎使用其他库(logback、slf4j 等)进行日志记录。我还了解到 springboot 可以配置为使用 log4j,并且由于我对 Spring 及其库还不太了解,所以我不知道如何获得我想要的结果。

最佳答案

当您定义组织记录器时,您需要在该记录器中传递附加程序引用希望这会起作用。

<Logger name="org" level="ALL" >
<AppenderRef ref="General"/>
</Logger>

Spring 默认使用 Commons Logging 库。您需要禁用它并使用 lg4j 库。您需要排除 commons-logging 依赖项。

<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>4.0.0.RELEASE</version>
<scope>runtime</scope>
<exclusions>
<exclusion>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
</dependencies>

您需要将 Log4j 放在类路径中,并为其提供一个配置文件,即类路径根目录中的 log4j.xml。并在 pom.xml 中添加以下依赖项。

<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.14</version>
<scope>runtime</scope>
</dependency>

引用 - http://docs.spring.io/spring/docs/4.0.0.RELEASE/spring-framework-reference/htmlsingle/#overview-not-using-commons-logging

关于java - spring 和 hibernate 的日志配置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41789306/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com