log4j的使用步骤:
1、建立一个maven工程,在pom.xml文件中加入下面的依赖
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
2、加入log4j.properties配置文件,在配置文件中加入相关配置,具体信息在最后面
3、在需要打印日志的类中加入下面的代码:
package com.lptxyl.log4j;
import org.apache.log4j.Logger;
public class Main {
//加入下面这句话,然后调用打印的方法即可
private static Logger logger = Logger.getLogger(Main.class);
public static void main(String[] args) {
logger.info("hello");
}
}
log4j的properties文件(log4j.properties)配置常用的属性如下:
log4j.properties:
log4j.rootLogger=DEBUG, Console ,DFile ,EFILE
#Console
log4j.appender.Console=org.apache.log4j.ConsoleAppender
log4j.appender.Console.layout=org.apache.log4j.TTCCLayout
#DEBUGFile
log4j.appender.DFile = org.apache.log4j.FileAppender
log4j.appender.DFile.File = C://DEBUG.log
log4j.appender.DFile.layout = org.apache.log4j.PatternLayout
log4j.appender.DFile.layout.ConversionPattern =%d [%t] %-5p [%c] - %m%n #%-5p表示日志级别占5个字符
log4j.appender.DFile.Threshold = DEBUG
#ERRORFile
log4j.appender.EFILE = org.apache.log4j.FileAppender
log4j.appender.EFILE.File = C://ERROR.log
log4j.appender.EFILE.layout = org.apache.log4j.PatternLayout
log4j.appender.EFILE.layout.ConversionPattern =%d [%t] %-5p [%c] - %m%n
log4j.appender.EFILE.Threshold = ERROR
其中每个属性的意思如下:
log4j.rootLogger=[level],appenderName,appenderName
log4j.rootLogger:表示输出的日志级别在level级别及以上的级别,意思就是只有级别大于或等于level才会
在控制台或者日志文件中输出
level:表示日志的级别,日志的级别由高到低:ERROR,WARN,INFO,DEBUG
appenderName:表示日志输出的位置,可以是任意的单词,只要后面的配置跟这个单词匹配即可
log4j.appender.appenderName:表示日志输出类型,其中有如下几种配置
org.apache.log4j.ConsoleAppender:输出到控制台
org.apache.log4j.FileAppender:输出到文件,使用比较少
org.apache.log4j.DailyRollingFileAppender:表示每天产生一个日志文件
org.apache.log4j.RollingFileAppender:表示文件大小到达指定尺寸的时候产生一个新的文件
org.apache.log4j.WriterAppender:将日志信息以流格式发送到任意指定的地方,用的少
log4j.appender.appenderName.File:表示日志输出到哪个指定的文件中,使用如下
log4j.appender.appenderName.File = C://DEBUG.log
log4j.appender.appenderName.layout:日志信息格式,有如下几种配置
org.apache.log4j.HTMLLayout:以HTML表格形式布局
org.apache.log4j.PatternLayout:可以灵活地指定布局模式,常用
org.apache.log4j.SimpleLayout:包含日志信息的级别和信息字符串
org.apache.log4j.TTCCLayout:包含日志产生的时间、线程、类别等等信息
log4j.appender.appenderName.layout.ConversionPattern:表示日志输出的具体格式,常用格式如下:
%m 输出代码中指定的消息;
%M 输出打印该条日志的方法名;
%p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL;
%r 输出自应用启动到输出该log信息耗费的毫秒数;
%c 输出所属的类目,通常就是所在类的全名;
%t 输出产生该日志事件的线程名;
%n 输出一个回车换行符,Windows平台为"rn”,Unix平台为"n”;
%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyyy-MM-dd
HH:mm:ss,SSS},输出类似:2002-10-18 22:10:28,921;
%l 输出日志事件的发生位置,及在代码中的行数;
log4j.appender.appenderName.Threshold:表示这个日志文件中只输出指定级别和指定级别以上的日志
log4j.logger.com.pengtxyl.netty.bio=bioAppender:表示将 com.pengtxyl.netty.bio 输出到 bioAppender 下
log4j.additivity.com.pengtxyl.netty.bio=false:表示com.pengtxyl.netty.bio下的日志不输出到根记录器下面,如
果为true,表示com.pengtxyl.netty.bio包下的日志也会输出到根记录器下面
=================================================================================
如果想对不同的类输出不同的文件(以cn.com.Test为例),先要在Test.java中定义:
private static Log logger = LogFactory.getLog(Test.class);
然后在log4j.properties中加入:
log4j.logger.cn.com.Test= DEBUG, test
log4j.appender.test=org.apache.log4j.FileAppender
log4j.appender.test.File=${myweb.root}/WEB-INF/log/test.log
log4j.appender.test.layout=org.apache.log4j.PatternLayout
log4j.appender.test.layout.ConversionPattern=%d %p [%c] - %m%n
也就是让cn.com.Test中的logger使用log4j.appender.test所做的配置。
如果在同一类中需要输出多个日志文件呢?其实道理是一样的,先在Test.java中定义:
private static Log logger1 = LogFactory.getLog(“myTest1”);
private static Log logger2 = LogFactory.getLog(“myTest2”);
然后在log4j.properties中加入:
log4j.logger.myTest1= DEBUG, test1
log4j.appender.test1=org.apache.log4j.FileAppender
log4j.appender.test1.File=${myweb.root}/WEB-INF/log/test1.log
log4j.appender.test1.layout=org.apache.log4j.PatternLayout
log4j.appender.test1.layout.ConversionPattern=%d %p [%c] - %m%n
log4j.logger.myTest2= DEBUG, test2
log4j.appender.test2=org.apache.log4j.FileAppender
log4j.appender.test2.File=${myweb.root}/WEB-INF/log/test2.log
log4j.appender.test2.layout=org.apache.log4j.PatternLayout
log4j.appender.test2.layout.ConversionPattern=%d %p [%c] - %m%n