gpt4 book ai didi

java - 如何使用相同的记录器将不同级别的日志记录到控制台+日志文件?

转载 作者:塔克拉玛干 更新时间:2023-11-03 04:55:42 25 4
gpt4 key购买 nike

我有一个 log4j 记录器,目前将日志写入控制台和文件,工作正常。

稍后我想将其配置为将 INFO + ERROR 记录到日志文件中,但仅在控制台上显示 ERROR。我必须改变什么才能实现这一目标?

log4j.rootLogger=INFO, console, MyFileAppender

log4j.logger.org.apache.cxf=INFO, console
log4j.logger.org.apache.cxf.interceptor.LoggingInInterceptor=INFO, console
log4j.logger.org.apache.cxf.interceptor.LoggingOutInterceptor=INFO, console

log4j.appender.console=org.apache.log4j.ConsoleAppender
log4j.appender.console.Target=System.out

log4j.appender.MyFileAppender=org.apache.log4j.RollingFileAppender
log4j.appender.MyFileAppender.Append=true
log4j.appender.MyFileAppender.File=c:/logs.log

此外,我想阻止将 CXF XML 请求记录到文件中。但我希望它们仍显示在控制台中。怎么办?

最佳答案

基于附加程序的配置

配置每个附加程序的日志级别必须单独完成,除非它与根级别配置相同。下面的示例 log4.properties 文件配置为将 INFO 及以上内容记录到控制台中,但仅将 ERROR 及以上内容记录到文件中。

log4j.appender.[appender-name].Threshold=[Level]

请看下面示例的最后一行(来自“How to integrate log4j with your Java project”)。

# root level configurations 
log4j.rootLogger=INFO,console,file

# configuration for console outputs
log4j.appender.console=org.apache.log4j.ConsoleAppender
log4j.appender.console.layout=org.apache.log4j.PatternLayout

# configuration for file output (into a file named messages.log)
log4j.appender.file=org.apache.log4j.RollingFileAppender
log4j.appender.file.File=messages.log
log4j.appender.file.layout=org.apache.log4j.PatternLayout

# threshold for file output
log4j.appender.file.Threshold=ERROR

基于包的日志级别

以下任何一项都会有所帮助。

log4j.logger.[package]=[Level]
log4j.logger.[package]=[Level], [Appender]

举个例子:

log4j.logger.org.apache.cxf=INFO, console

关于java - 如何使用相同的记录器将不同级别的日志记录到控制台+日志文件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19788839/

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