【发布时间】:2015-01-26 13:52:38
【问题描述】:
我正在启动新的 log4j2。我有一个问题,
我有一个 log4j2 xml 文件,我想将日志保存在自己的级别。 例如信息级别的日志保存在 info.txt 文件中,错误级别的日志保存在 error.txt 文件中。 这是我的 log4j2.xml 代码;
<Properties>
<Property name="log-path">logs</Property>
</Properties>
<Appenders>
<Console name="console-log" target="SYSTEM_OUT">
<PatternLayout pattern="[%-5level] %d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %c{1} - %msg%n" />
</Console>
<RollingFile name="trace-log"
filePattern="${log-path}/trace-%d{yyyy-MM-dd}.log"
fileName="${log-path}/trace.log" >
<PatternLayout pattern="[%-5level] %d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %c{1} - %msg%n"/>
<Policies>
<TimeBasedTriggeringPolicy modulate="true" interval="1" />
</Policies>
</RollingFile>
<RollingFile name="info-log"
filePattern="${log-path}/info-%d{yyyy-MM-dd}.log"
fileName="${log-path}/info.log">
<PatternLayout pattern="[%-5level] %d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %c{1} - %msg%n"/>
<Policies>
<TimeBasedTriggeringPolicy modulate="true" interval="1" />
</Policies>
</RollingFile>
<RollingFile name="error-log"
filePattern="${log-path}/error-%d{yyyy-MM-dd}.log"
fileName="${log-path}/error.log">
<PatternLayout pattern="[%-5level] %d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %c{1} - %msg%n"/>
<Policies>
<TimeBasedTriggeringPolicy modulate="true" interval="1" />
</Policies>
</RollingFile>
</Appenders>
<Loggers>
<Logger name="com.test.log4j2" level="debug">
<appender-ref level="debug" ref="trace-log" />
<appender-ref level="error" ref="error-log" />
<appender-ref level="debug" ref="console-log" />
<appender-ref level="info" ref="info-log" />
</Logger>
<Root additivity="false" level="info">
<AppenderRef ref="error-log" />
</Root>
</Loggers>
感谢您的帮助。
【问题讨论】:
-
它是否有效?如果不是,那是什么问题?
-
只是保存error.log文件。信息日志未保存。
-
那是因为你在根记录器中定义了它。
-
所以?我该如何解决?