时间:2022-07-08 10:26:28 | 栏目:JAVA代码 | 点击:次
这里用的是org.apache.log4j.Logger
log4j.rootLogger=error, stdout log4j.appender.appenderName=org.apache.log4j.AsyncAppender log4j.appender.stdout=org.apache.log4j.ConsoleAppender log4j.appender.stdout.Target=System.out log4j.appender.stdout.layout=org.apache.log4j.PatternLayout log4j.appender.stdout.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n #only time no date.outfile1 has date log4j.logger.com.ht=info,outfile1 log4j.appender.outfile1=org.apache.log4j.RollingFileAppender log4j.appender.outfile1.File=log/ht.log log4j.appender.outfile1.MaxFileSize=100MB log4j.appender.outfile1.MaxBackupIndex=50 log4j.appender.outfile1.layout=org.apache.log4j.PatternLayout log4j.appender.outfile1.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %5p %c{1}:%L - %m%n log4j.logger.com.ht.log=info,outfile2 log4j.appender.outfile2=org.apache.log4j.RollingFileAppender log4j.appender.outfile2.File=log/ht2.log log4j.appender.outfile2.MaxFileSize=100MB log4j.appender.outfile2.MaxBackupIndex=50 log4j.appender.outfile2.layout=org.apache.log4j.PatternLayout log4j.appender.outfile2.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %5p %c{1}:%L - %m%n
然后有两个类,Test1在com.ht包下面,Test2在com.ht.log包下面。每个下面打印一句:logger.info();
Test1将输出到控制台和ht.log
Test2将输出到控制台和ht.log和ht2.log
注意这里rootLogger的级别可是error,可见这里的级别不起作用。
其实,这里的error只对于没有申明appender的包才起作用。如果去掉log4j.logger.com.ht.log这一句,Test1没有任何输出,除非logger.error才会输出到控制台。
第二点:凡是申明appender的包,不论申明级别一定会包含rootLogger的输出,如果同时指定了outfile,那么日志会出现两份。
第三点:com.ht.log这个包下面的类可以匹配到所有上级目录的设置。
日志怎么设置要想清楚啊!不然这一句打到控制台那句打到文件,出问题了查出来的日志不连贯,好几个文件查来查去。
log4j.additivity.com.ht=false 可以不写入rootLogger。默认是true
log4j.rootLogger = [ level ] , appenderName1, appenderName2, …
level
:是日志记录的优先级,分为OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL或者您定义的级别。Log4j建议只使用四个级别,优先级从高到低分别是ERROR、WARN、INFO、DEBUG。
通过在这里定义的级别,您可以控制到应用程序中相应级别的日志信息的开关。
比如在这里定义了INFO级别,则应用程序中所有DEBUG级别的日志信息将不被打印出来。
appenderName:就是指定日志信息输出到哪个地方。您可以同时指定多个输出目的地。
例如:
log4j.rootLogger=info,A1,B2,C3 配置了3个输出地方,这个名字可以任意(如上面的db),但必须与我们在后面进行的设置名字对应;