log4j的配置

先来从网上找来一段log4j.properties的配置,修改一番:

##level 是日志记录的优先级,ALL < DEBUG < INFO <WARN < ERROR < FATAL < OFF
log4j.rootLogger = error ,  stdout ,  D ,  E 

### 输出到控制台 ###
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
# 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL 对应 5,4,3,2,1
log4j.appender.stdout.layout.ConversionPattern =  %-d{ABSOLUTE} %-5p [%F:%L] - %m%n

#### 输出到日志文件 ###
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
log4j.appender.D.File = logs/log.log
log4j.appender.D.Append = true
## 输出DEBUG级别以上的日志,如果这个级别优先级小雨 rootLooger定义的级别 则不输出;
log4j.appender.D.Threshold = DEBUG
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n

### 保存异常信息到单独文件 ###
log4j.appender.E = org.apache.log4j.DailyRollingFileAppender
## 异常日志文件名
log4j.appender.E.File = logs/error.log 
log4j.appender.E.Append = true
## 只输出ERROR级别以上的日志!!!
log4j.appender.E.Threshold = ERROR 
log4j.appender.E.layout = org.apache.log4j.PatternLayout
log4j.appender.E.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n

 把该文件放到src\main\resources目录下面,

 

写一个简单的测试程序TestLog4j.java;

 

public class TestLog4j {
	static Log logger = LogFactory.getLog(TestLog4j.class); 
	public static void main(String[] args) {
		PropertyConfigurator
		.configure("src\\main\\resources\\log4j.properties");
//		 输出优先级,DEBUG < INFO <WARN < ERROR < FATAL
		logger.debug( " debug " );
		logger.info( " info " );
		logger.warn(" warn ");
                logger.error( " error " );
	}
}
 结果输出为:
20:09:23,126 ERROR [TestLog4j.java:22] - error

 现象描述完了,下面就来探讨上述配置文件中各个配置的作用把。

 

(1).配置根Logger,其语法为:  

log4j.rootLogger = level,appenderName1,appenderName2

level 是日志记录的优先级,ALL < DEBUG < INFO <WARN < ERROR < FATAL < OFF

这里配置的level是error,在

*注意*

在使用log4j 1.2.12版本时候,打印的结果为,TestLog4j运行结果为:

20:12:43,754 DEBUG [TestLog4j.java:19] -  debug 
20:12:43,754 INFO  [TestLog4j.java:20] -  info 
20:12:43,754 WARN  [TestLog4j.java:21] -  warn 
20:12:43,754 ERROR [TestLog4j.java:22] -  error 

怀疑是再1.2.12及其以前版本时候log4j.rootLogger 配置level不起作用。

我当前使用版本为1.2.16.

 

(2).  配置日志信息输出目的地Appender,其语法为:

log4j.appender.appenderName=log4j提供的appender类

log4j.appender.appenderName.属性=属性值



 3).配置日志信息的格式(布局)

log4j.appender.appenderName.layout = log4j提供的layout类log4j.appender.appenderName.layout.属性 = 值


 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值