我将 spring 启动应用程序更改为 spring mvc,但我的 log4j2.xml 不起作用?



我将 spring boot 更改为 spring MVC,但我在日志文件中看不到任何日志信息,但它填充在控制台中。请让我知道我需要在 log4j2.xml 文件中所做的更改,以便将日志信息保存到日志文件中。

在下面的XML文件中,什么是监视器间隔= 30

非常感谢您的回复

<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="WARN" monitorInterval="30">
<Properties>
<Property name="LOG_PATTERN">
%d{yyyy-MM-dd HH:mm:ss.SSS} %5p ${hostName} --- [%15.15t] %-40.40c{1.} : %m%n%ex
</Property>
</Properties>
<Appenders>
<Console name="ConsoleAppender" target="SYSTEM_OUT" follow="true">
<PatternLayout pattern="${LOG_PATTERN}"/>
</Console>
<!-- Rolling File Appender -->
<RollingFile name="FileAppender" fileName="logs/prism.log"
filePattern="logs/prism-%d{yyyy-MM-dd}-%i.log.zip">
<PatternLayout>
<Pattern>${LOG_PATTERN}</Pattern>
</PatternLayout>
<Policies>
<SizeBasedTriggeringPolicy size="5 MB"/>
</Policies>
<DefaultRolloverStrategy max="10"/>
</RollingFile>
</Appenders>
<Loggers>
<Logger name="com.heymath" level="debug"
additivity="false">
<AppenderRef ref="ConsoleAppender"/>
<AppenderRef ref="FileAppender"/>
</Logger>
<Root level="info">
<AppenderRef ref="ConsoleAppender"/>
<AppenderRef ref="FileAppender"/>
</Root>
</Loggers>
</Configuration>

> monitorInterval=30 告诉 Log4j2 每 30 秒检查一次,以查看日志记录配置是否已更改,如果已更改,则重新配置。

我认为您的配置没有明显问题。它应该将所有信息,警告,错误和致命消息记录到文件和控制台中。来自com.heymath记录器的调试消息也应该在那里。

我建议在配置元素上将状态="WARN"更改为状态="调试"。如果您没有看到来自 log4j 的日志,则表示您的配置文件未找到且未被使用。相反,它使用将错误记录到控制台的默认配置。

最新更新