Java Log4j2-Log4j2.xml配置
我开始新的log4j2。我有一个问题 我有一个log4j2xml文件,我想在自己的级别保存日志。 例如,信息级别日志保存在info.txt文件中,错误级别日志保存在error.txt文件中。 这是我的log4j2.xml代码Java Log4j2-Log4j2.xml配置,java,logging,log4j,log4j2,Java,Logging,Log4j,Log4j2,我开始新的log4j2。我有一个问题 我有一个log4j2xml文件,我想在自己的级别保存日志。 例如,信息级别日志保存在info.txt文件中,错误级别日志保存在error.txt文件中。 这是我的log4j2.xml代码 <Properties> <Property name="log-path">logs</Property> </Properties> <Appenders> <Console name
<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>
日志
谢谢您的帮助。您不需要为此定义单独的记录器 尝试以下方法:
<Loggers>
<Root level="trace">
<AppenderRef level="DEBUG" ref="trace-log" />
<AppenderRef level="ERROR" ref="error-log" />
<AppenderRef level="DEBUG" ref="console-log" />
<AppenderRef level="INFO" ref="info-log" />
</Root>
</Loggers>
我使用过滤器解决了问题
<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" >
<Filters>
<ThresholdFilter level="warn" onMatch="DENY" onMismatch="NEUTRAL"/>
<ThresholdFilter level="error" onMatch="DENY" onMismatch="NEUTRAL"/>
<ThresholdFilter level="fatal" onMatch="DENY" onMismatch="NEUTRAL"/>
<ThresholdFilter level="info" onMatch="DENY" onMismatch="NEUTRAL"/>
<ThresholdFilter level="debug" onMatch="DENY" onMismatch="NEUTRAL"/>
<ThresholdFilter level="TRACE" onMatch="ACCEPT" onMismatch="DENY"/>
</Filters>
<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">
<Filters>
<ThresholdFilter level="warn" onMatch="DENY" onMismatch="NEUTRAL"/>
<ThresholdFilter level="error" onMatch="DENY" onMismatch="NEUTRAL"/>
<ThresholdFilter level="fatal" onMatch="DENY" onMismatch="NEUTRAL"/>
<ThresholdFilter level="INFO" onMatch="ACCEPT" onMismatch="DENY"/>
</Filters>
<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>
<Root level="trace">
<AppenderRef level="DEBUG" ref="trace-log" />
<AppenderRef level="ERROR" ref="error-log" />
<AppenderRef level="DEBUG" ref="console-log" />
<AppenderRef level="INFO" ref="info-log" />
日志
谢谢。它能用吗?如果不是,问题是什么?它只是保存error.log文件。信息日志未保存。这是因为您在root logger.so中定义了它?我怎么修复它呢?我累了,但是所有的日志文件都是一样的。我只需要,error.log文件中的错误日志,info.log文件中的信息日志。但在您的代码中,三个文件具有相同的日志值。当我编写“logger.trace()”时,它应该保存在trace.log文件中。当我写“logger.info()”时,它应该保存在info.log文件中。当我编写“logger.error()”时,它应该保存在error.log文件中。但是在这里trace.log文件、info.log文件和error.log文件都有错误级别的消息。所有文件的日志值都是一样的。我不确定你的配置是什么,但即使它说了同样的感谢你的兴趣。显然你不明白阈值过滤器是如何工作的。