Log4J 基本使用

Log4j由三个重要的组件  成:日志 信息 的优先级,日志信息的输出目的地,日志信息的输出格式。 
日志信息的优先级 从高到低有ERROR  WARN  INFO  DEBUG ,分别用来指定这条日志信息的重要程度。

日志信息的输出目的 地指定了日志将打印到控制台还是文件中;而输出格式则控制了日志信息的显示内容。

配置根 Logger ,其语法为:

log4j.rootLogger = [ level ] , appenderName, appenderName, …

※  level  是日志记录的优先级,分为OFF  FATAL  ERROR  WARN  INFO  DEBUG  ALL 或者您定义的级别。 Log4j 建议只使用四个级别,优 先级从高到低分别是 ERROR  WARN  INFO  DEBUG 。通过在这里定义的级别,您可以控制到应用程序中相应级别的日志信息的开关。指定输出只显 示比该级别以上的信息,所有比该级别低的信息都不会被显示。比如在这里定义了 INFO 级别,则应用程序中所有 DEBUG 级别的日志信息将不被打印出来。

※  appenderName 就是指定日志信息输出到哪个地方。您可以同时指定多个输出目的地。

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

log4j.appender.appenderName = fully.qualified.name.of.appender.class

※ Log4j提供的 appender 有以下几种:

org.apache.log4j.ConsoleAppender(控制台)

org.apache.log4j.FileAppender(文件)

org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件)

org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件)

org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)

配置日志信息的格式(布局),其语法为:

log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class

※ Log4j提供的 layout 有以下几种:

org.apache.log4j.HTMLLayout(以 HTML 表格形式布局),

org.apache.log4j.PatternLayout(可以灵活地指定布局模式),

org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),

org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)

  当layout  PatternLayout 时, ConversionPattern 的格式有下面选项:

%r: 自程序开始后消耗的毫秒数

%t: 表示日志记录请求生成的线程

%p: 表示日志语句的优先级

%r: 与日志请求相关的类别名称

%c: 信息所在的类名

%m%n: 表示消息的内容

*************************代码中的使用 *******************************

1. import中加入以下几行:

import org.apache.log4j.PropertyConfigurator ;

import org.apache.log4j.Logger ;

import org.apache.log4j.Level ;

2. 定义 Logger 变量 :

static Logger logger = Logger.getLogger(ServerWithLog4j.class.getName ()) ;

3. 读配置文件 :

PropertyConfigurator.configure (String settingfilename) ;

4. 显示日志信息 :

按显示级别显示日志信息 logger.debug(String log_info);

用于显示调试信息 logger.info (String log_info);

用于显示系统提示信息 logger.warn(String log_info);

用于显示警告或特殊提示 logger.error(String log_info);

用于显示错误信息,一般在异常中使用。

********************************************************************************************

java代码中添加如下语句

static {
        // 启动日志de
        try {
            PropertyConfigurator.configure(QuartzTest.class.getClassLoader()
                    .getResource("").toURI().getPath()
                    + "conf/log4j.properties");
        } catch (Exception e) {
        }
    }

src/conf/log4j.properties

log4j.rootLogger=INFO,A1,A2,A3
log4j.appender.A1=org.apache.log4j.ConsoleAppender
log4j.appender.A1.Threshold=INFO
log4j.appender.A2=org.apache.log4j.DailyRollingFileAppender 
log4j.appender.A2.Threshold=INFO 
log4j.appender.A2.File=./log/dailyLog/ENDailyRollingLog.log 
log4j.appender.A2.DatePattern='.'yyyy-MM-dd'.log'
log4j.appender.A3=org.apache.log4j.RollingFileAppender 
log4j.appender.A3.Threshold=INFO
log4j.appender.A3.File=./log/ENRollingLog.log
log4j.appender.A3.MaxFileSize=5MB
log4j.appender.A3.MaxBackupIndex=5
log4j.appender.A1.layout=org.apache.log4j.PatternLayout 
log4j.appender.A1.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} <# %l> %-5p [%r]:%n%m%n
log4j.appender.A2.layout=org.apache.log4j.PatternLayout 
log4j.appender.A2.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} <# %l> %-5p [%r]:%n%m%n
log4j.appender.A3.layout=org.apache.log4j.PatternLayout 
log4j.appender.A3.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} <# %l> %-5p [%r]:%n%m%n

 

 

posted @ 2013-10-21 15:37  杨桃  阅读(585)  评论(0编辑  收藏  举报