gpt4 book ai didi

java - 使用 Log4j2 记录 Spring

转载 作者:IT老高 更新时间:2023-10-28 13:50:38 24 4
gpt4 key购买 nike

我正在尝试使用 Log4j2 将 spring 日志打印到文件和控制台中。我想这是我的 Log4j2 配置中的一个问题。我无法让它工作。我的 log4j2.xml 文件中有这个配置:

<?xml version="1.0" encoding="UTF-8"?>
<configuration name="defaultConfiguration" status="warn" strict="true" monitorInterval="5">
<properties>
<property name="patternlayout">%d{ISO8601} [%t] %-5level %logger{36} - %msg%n%throwable{full}</property>
<property name="filename">${env:MY_ROOT}/logs/mylog.log</property>
<property name="filenamePattern">${env:MY_ROOT}/logs/mylog-%d{yyyy-dd-MM}-%i.log.gz</property>
</properties>
<appenders>
<appender name="Console" type="Console" target="SYSTEM_OUT">
<layout type="PatternLayout" pattern="${patternlayout}" />
</appender>
<appender name="File" type="RollingFile" fileName="${filename}" filePattern="${filenamePattern}" bufferedIO="true" immediateFlush="true"
append="true">
<layout type="PatternLayout" pattern="${patternlayout}" />
<Policies>
<TimeBasedTriggeringPolicy />
<SizeBasedTriggeringPolicy size="50 MB" />
</Policies>
<DefaultRolloverStrategy max="30" />
</appender>
<appender name="AsynchFile" type="asynch" blocking="true" bufferSize="128">
<appender-ref ref="File" />
</appender>
</appenders>
<loggers>
<root level="info">
<appender-ref ref="Console" />
<appender-ref ref="AsynchFile" />
</root>
<logger name="org.springframework.beans">
<appender-ref ref="Console" />
<appender-ref ref="AsynchFile" />
</logger>
</loggers>
</configuration>

这些是我的 pom 文件中的依赖项:(可能其中一些不是必需的)

<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.6.6</version>
</dependency>

<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>1.6.6</version>
</dependency>

<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-api</artifactId>
<version>2.0-beta5</version>
</dependency>

<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>2.0-beta5</version>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-1.2-api</artifactId>
<version>2.0-beta5</version>
</dependency>

<dependency>
<groupId>com.lmax</groupId>
<artifactId>disruptor</artifactId>
<version>3.0.0.beta3</version>
</dependency>

我没有在我的 Java 代码中做任何与 spring 相关的事情。我正在使用 Apache Camel 的 Main 类,它读取我的 spring 配置并加载 bean。

我做错了什么?谢谢!

编辑:我没有在任何输出(控制台或文件)中获得 spring 日志。但是,我能够获取在我的 java 代码中创建的日志。我希望这个澄清会有所帮助。

最佳答案

这个问题是spring使用common-logging 1.X引起的,所以如果你想把这个日志路由到Log4j 2,你需要在你的pom.xml中添加依赖

<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-jcl</artifactId>
<version>2.1</version>
</dependency>

不要删除您的 common-logging 1.X 依赖项

关于java - 使用 Log4j2 记录 Spring,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16341020/

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