log4j是java中一个记录日志的组件,通过log4j可以灵活的控制日志文件的格式,大小,日志级别,日志输出位置。配置灵活方便,而且还不用考虑线程.
1.示例
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
添加log4j.properties配置文件
log4j.rootLogger=info, stdout, log, errorlog
###Console ###
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} [ %t ] [ %p ]:%L - %m%n
### Log ###
log4j.appender.log = org.apache.log4j.DailyRollingFileAppender
log4j.appender.log.File = log/log.log
log4j.appender.log.Append = true
log4j.appender.log.Threshold = INFO
log4j.appender.log.DatePattern='.'yyyy-MM-dd'.log'
log4j.appender.log.layout = org.apache.log4j.PatternLayout
log4j.appender.log.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t ] %m%n
### Error ###
log4j.appender.errorlog = org.apache.log4j.DailyRollingFileAppender
log4j.appender.errorlog.File = log/errorlog.log
log4j.appender.errorlog.Append = true
log4j.appender.errorlog.Threshold = ERROR
log4j.appender.errorlog.DatePattern='.'yyyy-MM-dd
log4j.appender.errorlog.layout = org.apache.log4j.PatternLayout
log4j.appender.errorlog.layout.ConversionPattern =%-d{yyyy-MM-dd HH:mm:ss} [ %t ] %m%n
记录日志
public static void main( String[] args )
{
Logger logger = Logger.getLogger(App.class);
logger.info("输出正常信息");
logger.error("输出错误信息");
}
2.详解
log4j.rootLogger=info, stdout, log, errorlog 表示将info信息输出到stdout,log,errorlog中
即下面的log4j.appender.stdout,log4j.appender.log,log4j.appender.errorlog
org.apache.log4j.DailyRollingFileAppender 表示每天产生一个日志文件
org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件)
log4j.appender.log = org.apache.log4j.DailyRollingFileAppender 指定每天产生一个日志文件
log4j.appender.log.File = log/log.log 指定输出路径
log4j.appender.log.Append = true true表示追加内容,false表示覆盖内容
log4j.appender.log.Threshold = INFO 指定输出级别
log4j.appender.log.DatePattern='.'yyyy-MM-dd 指定文件名格式
log4j.appender.log.layout = org.apache.log4j.PatternLayout 指定日志布局格式
log4j.appender.log.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t ] %m%n 指定日志输出格式
log4j.appender.log.layout主要有以下四种布局
1.org.apache.log4j.HTMLLayout(以HTML表格形式布局),
2.org.apache.log4j.PatternLayout(可以灵活地指定布局模式),
3.org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),
4.org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
org.apache.log4j.ConsoleAppender表示输出到控制台,即程序运行的时候会在控制台Console显示,同时会记录到日志文件中
org.apache.log4j.FileAppender(文件)表示输出到文件
%m 输出代码中指定的消息
%p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL
%r 输出自应用启动到输出该log信息耗费的毫秒数
%c 输出所属的类目,通常就是所在类的全名
%t 输出产生该日志事件的线程名
%n 输出一个回车换行符,Windows平台为“\r\n”,Unix平台为“\n”
%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,
%l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。