zoukankan      html  css  js  c++  java
  • 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

     

  • 相关阅读:
    Linux远程复制scp和rsync区别
    一个线上问题的思考:Eureka注册中心集群如何实现客户端请求负载及故障转移?
    docker离线安装
    centos7 docker 宿主机不能访问容器问题解决
    nginx 或 tengine安装错误提示:./configure: error: the HTTP rewrite module requires the PCRE library
    redhat 安装中文 支持中文
    rpm忽略依赖,强制安装,加--force --nodeps ( warning: perl-Test-Nginx-0.28-1.el6_10.noarch.rpm: Header V4 RSA/SHA1 Signature, key ID d5edeb74: NOKEY error: Failed dependencies:)
    redhat6 安装openresty
    redhat6 Unable to establish SSL connection.
    Lua入门脚本(与Redis结合)
  • 原文地址:https://www.cnblogs.com/tomcattd/p/3380694.html
Copyright © 2011-2022 走看看