zoukankan      html  css  js  c++  java
  • logger日志级别

    Level描述
    ALL 各级包括自定义级别
    DEBUG 指定细粒度信息事件是最有用的应用程序调试
    ERROR 错误事件可能仍然允许应用程序继续运行
    FATAL 指定非常严重的错误事件,这可能导致应用程序中止
    INFO 指定能够突出在粗粒度级别的应用程序运行情况的信息的消息
    OFF 这是最高等级,为了关闭日志记录
    TRACE 指定细粒度比DEBUG更低的信息事件
    WARN 指定具有潜在危害的情况

    日志级别是如何工作?

    级别p的级别使用q,在记录日志请求时,如果p>=q启用。这条规则是log4j的核心。它假设级别是有序的。对于标准级别它们关系如下:ALL < DEBUG < INFO < WARN < ERROR < FATAL < OFF。

    下面的例子明确指出如何可以过滤所有的DEBUG和INFO消息。这个程序使用记录并执行setLevel(Level.X)方法来设置所需的日志记录级别:

    这个例子将打印,除了调试和信息的所有消息:

    import org.apache.log4j.*;
    
    public class LogClass {
       private static org.apache.log4j.Logger log = Logger
                                        .getLogger(LogClass.class);
       public static void main(String[] args) {
          log.setLevel(Level.WARN);
    
          log.trace("Trace Message!");
          log.debug("Debug Message!");
          log.info("Info Message!");
          log.warn("Warn Message!");
          log.error("Error Message!");
          log.fatal("Fatal Message!");
       }
    }

    当编译并运行LogClass程序会产生以下结果:

    Warn Message!
    Error Message!
    Fatal Message!

    使用配置文件设置级别:

    Log4j提供这些可以让程序员自由更改源代码,改变调试级别的配置级别是基于文件设置。

    以下是上面的例子使用 log.setLevel(Level.WARN)方法的配置文件与上面的例子例子功能一样。

    # Define the root logger with appender file
    log = /usr/home/log4j
    log4j.rootLogger = WARN, FILE
    
    # Define the file appender
    log4j.appender.FILE=org.apache.log4j.FileAppender
    log4j.appender.FILE.File=${log}/log.out
    
    # Define the layout for file appender
    log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
    log4j.appender.FILE.layout.conversionPattern=%m%n

    现在,使用下面的程序:

    import org.apache.log4j.*;
    
    public class LogClass {
       private static org.apache.log4j.Logger log = Logger
                                        .getLogger(LogClass.class);
       public static void main(String[] args) {
          log.trace("Trace Message!");
          log.debug("Debug Message!");
          log.info("Info Message!");
          log.warn("Warn Message!");
          log.error("Error Message!");
          log.fatal("Fatal Message!");
       }
    }

    现在,编译和运行上面的程序,得到以下结果在 /usr/home/log4j/log.out 文件:

    Warn Message!
    Error Message!
    Fatal Message!
    转自:http://www.yiibai.com/log4j/log4j_logging_levels.html
  • 相关阅读:
    Asp.net 程序连接orcle如果在安装 32 位 Oracle 客户端组件的情况下以 64 位模式运行,
    Navicat 远程连接 Oracle11g 数据库报错 No listener 的问题
    springMVC中@DateTimeFormat 失效的处理
    单例设计模式中懒汉式线程安全的处理
    ajax同步请求
    vue.js在标签属性中拼接字符串
    vue.js进行遍历
    html页面之间的传值
    URL编码和解码的一个小问题(JS方法和JAVA方法)
    SolrJ的配置及使用
  • 原文地址:https://www.cnblogs.com/shaozhiqi/p/5045754.html
Copyright © 2011-2022 走看看