Log4j 是做什么的
Log4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件、甚至是套接口服务器、NT的事件记录器、UNIX Syslog守护进程等;我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,能够更加细致地控制日志的生成过程,而这些可以通过一个配置文件来灵活地进行配置,不需要修改应用的代码。Log4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件、甚至是套接口服务器、NT的事件记录器、UNIX Syslog守护进程等;我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,能够更加细致地控制日志的生成过程,而这些可以通过一个配置文件来灵活地进行配置,不需要修改应用的代码。
log4j必须要掌握的三个组件
(1) Logger : 负责输出信息日志信息,并能够对日志信息过滤,确定哪些日志信息输出,哪些信息被忽略。
(2) Appender : 指定日志输出到什么地方,可以是控制台、文件或网络设备等等。
(3) Layouts : 加在Appender后面用以实现格式化输出日志的内容。
log4j设置
(1) 下载log4j软件包(官网下载地址: Apache log4j)
(2) 引入下载log4j的jar包到lib目录。
(3)在CLASSPATH下建立log4j.properties或XML格式的配置文件。
配置文件如下:
</pre><pre name="code" class="html"><span style="font-family: Arial;font-size:10px; line-height: 26px; background-color: rgb(238, 238, 238);">#配置根Logger</span>
log4j.rootLogger = debug,stdout,E
<span style="font-family: Arial;font-size:10px; line-height: 26px; background-color: rgb(238, 238, 238);"><span style="font-family: Arial;font-size:10px; line-height: 26px; background-color: rgb(238, 238, 238);">### 输出到控制台 ###</span></span>
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Threshold = debug
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
<span style="font-family: Arial;font-size:10px; line-height: 26px; background-color: rgb(238, 238, 238);">### 输出到日志文件 ###</span>
log4j.logger.org.hibernate.cache=debug
log4j.appender.E= org.apache.log4j.DailyRollingFileAppender
log4j.appender.E.File =C:/LOG4J/logs/log_
log4j.appender.E.DatePattern=yyyy-MM-dd'.log'
log4j.appender.E.Threshold = debug
log4j.appender.E.layout = org.apache.log4j.PatternLayout
log4j.appender.E.layout.ConversionPattern =%-d{yyyy-MM-dd HH\:mm\:ss}[%c] [%t\:%r] - [%p] %m%n
log4j配置文件详解
(一) log4j.rootLogger的第一个参数为输出日志的级别,下面是其五个级别:
FATAL 0
ERROR 3
WARN 4
INFO 6
DEBUG 7
log4j.rootLogger后面的两个参数意为将等级为debug的日志信息输出到stdout和E这两个目的地,stdout和E的定义在下面的代码,可以任意起名。
定义为stdout的输出端可以是以下五种:
(1)org.apache.log4j.ConsoleAppender(控制台)
(2)org.apache.log4j.FileAppender(文件)
(3)org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件)
(4)org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件)
(5)org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)
定义为E的输出端解释如下:
log4j.appender.E= org.apache.log4j.DailyRollingFileAppender,定义名为E的输出端的类型为每天产生一个日志文件。
log4j.appender.E.File =C:/LOG4J/logs/log_,此句为定义名为E的输出端的文件名为C:/LOG4J/logs/log_。
log4j.appender.E.DatePattern=yyyy-MM-dd'.log',日志后缀格式。
log4j.appender.E.Threshold = debug,只输出debug以上级别的日志。
log4j.appender.E.layout = org.apache.log4j.PatternLayout,此句为定义名为stdout的输出端的layout是哪种类型。可以是以下4种类型:
(1) org.apache.log4j.HTMLLayout(以HTML表格形式布局)
(2) org.apache.log4j.PatternLayout(可以灵活地指定布局模式)
(3)org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串)
(4)org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)
log4j.appender.E.layout.ConversionPattern =%-d{yyyy-MM-dd HH\:mm\:ss}[%c] [%t\:%r] - [%p] %m%n,如果使用pattern布局就要指定的打印信息的具体格式 ConversionPattern,打印参数如下:
(1) %m 输出代码中指定的消息
(2)%p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL
(3) %r 输出自应用启动到输出该log信息耗费的毫秒数
(4) %c 输出所属的类目,通常就是所在类的全名
(5) %t 输出产生该日志事件的线程名
(6) %n 输出一个回车换行符,Windows平台为“rn”,Unix平台为“n”
(7)%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyyy MMM dd HH:mm:ss,SSS},输出类似:2014年12月10日 22: 10:28,921
(8)%l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。
(二) log4j的其他参数说明:
log4j.logger.org.hibernate.cache=debug,指定org.hibernate.cache包下的所有类的等级为DEBUG。
log4j.appender.stdout.Threshold = debug,输出DEBUG级别以上的日志。
在代码中使用log4
(1)导入所有需的commongs-logging类:
import org.apache.commons.logging.Log
import org.apache.commons.logging.LogFactory;
(2)在自己的类中定义一个org.apache.commons.logging.Log类的私有静态类成员:
private final Log log = LogFactory.getLog(getClass());
LogFactory.getLog()方法的参数使用的是当前类的class。
(3)使用org.apache.commons.logging.Log类的成员方法输出日志信息:
public class HMain {
static Logger log4j = Logger.getLogger(HMain.class.getClass());
public HMain(){
System.out.println("hello, I am HMain");
printLog();
}
private void printLog(){
BasicConfigurator.configure();
PropertyConfigurator.configure( " D:/Code/conf/log4j.properties " );
DOMConfigurator.configure("");
log4j.debug("log4j debug");
log4j.info("log4j info");
log4j.warn("log4j warn");
log4j.error("log4j error");
log4j.fatal("log4j fatal");
}
}