log4j配置说明

## 本文属于整理记录、方便以后使用、内容是在网上检索得到
 
配置文件如下:

##############注释begin##############
#另外,也可以指定按周、天、时、分等来滚动日志文件,对应的格式如下:
#log4j.appender.info.datePattern
#1) yyyy-MM:每月
#2) yyyy-ww:每周
#3) yyyy-MM-dd:每天
#4) yyyy-MM-dd-a:每天两次
#5) yyyy-MM-dd-HH:每小时
#6) yyyy-MM-dd-HH-mm:每分钟

#配置日志信息的输出格式(Layout):
#log4j.appender.appenderName.layout=className
#className:可设值如下:
#(1)org.apache.log4j.HTMLLayout(以HTML表格形式布局)
#(2)org.apache.log4j.PatternLayout(可以灵活地指定布局模式)
#(3)org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串)
#(4)org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)

#日志输出位置(文件、控制台)
#log4j.appender.error
#org.apache.log4j.ConsoleAppender(控制台)
#org.apache.log4j.FileAppender(文件)
#org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件)
#org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件)
#org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)
##############注释end##############

##############配置begin##############
### set log levels ### 
log4j.rootLogger=info,error,info  
log4j.appender.stdout=org.apache.log4j.ConsoleAppender     
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout     
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd-HH-mm} [%t] [%c] [%p] - %m%n     

log4j.logger.info=info  
log4j.appender.info=org.apache.log4j.DailyRollingFileAppender
log4j.appender.info.layout=org.apache.log4j.PatternLayout     
log4j.appender.info.layout.ConversionPattern=%d{yyyy-MM-dd-HH-mm} [%t] [%c] [%p] - %m%n  
log4j.appender.info.datePattern='.'yyyy-MM-dd   
log4j.appender.info.Threshold = INFO   
log4j.appender.info.append=false
log4j.appender.info.File=D:/log4j/info.log
#log4j.appender.info.MaxFileSize=1MB
#log4j.appender.info.MaxBackupIndex=5

# 日志级别
log4j.logger.error=error
# 日志输出类型
log4j.appender.error=org.apache.log4j.DailyRollingFileAppender
# 日志输出样式
log4j.appender.error.layout=org.apache.log4j.PatternLayout
log4j.appender.error.layout.ConversionPattern=%d{yyyy-MM-dd-HH-mm} [%t] [%c] [%p] - %m%n
# 日志滚动周期
log4j.appender.error.datePattern='.'yyyy-MM-dd
# 指定当前级别以上的都输出
log4j.appender.error.Threshold = ERROR
# 输出方式(追加 或 覆盖)
log4j.appender.error.append=false
# 日志输出位置
log4j.appender.error.File=D:/log4j/error.log
# 日志文件最大存储大小
#log4j.appender.error.MaxFileSize=1MB
#log4j.appender.error.MaxBackupIndex=5
##############配置end##############



注意点:
当log4j.appender.error.Threshold = info   时输出的日志信息不仅包括info级别同时会输出比指定级别更高的日志信息
解决方法:定义自己的Appender类,继承DailyRollingFileAppender,改写针对Threshold 的设置说明(重写针对级别的比较方法)
定义自己的Appender类,继承DailyRollingFileAppender,改写针对Threshold 的设置说明(重写针对级别的比较方法)
(如果自己重写isAsSevereAsThreshold方法需要修改log4j.appender.error=xxx 的值 比如:log4j.appender.error = xxx.xxx.MyAppender</span>

下面是重写方法:
public boolean isAsSevereAsThreshold(Priority priority)  {    
     return threshold == null || priority.isGreaterOrEqual(threshold);    
}

public class MyAppender extends DailyRollingFileAppender {  
      
    @Override  
    public boolean isAsSevereAsThreshold(Priority priority) {    
          //只判断是否相等,而不判断优先级     
        return this.getThreshold().equals(priority);    
    }    
} 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值