Java中的日志级别

昨天校招面试被问到了Java中的日志等级,当时也慌的一批,只说出了其中的三个,在这里细心为大家总结一下。

java中⽇志级别有7 个级别:

        severe、Warning、info、config、fine、finer、finest。

默认情况只记录前三个级别。

另外可以使⽤log4j定义的8个级别的log:

        (除去OFF和ALL,可以说分为6个级别),优先级从高到低依次为:

        OFF、FATAL、ERROR、WARN、INFO、DEBUG、TRACE、 ALL。

        log4j规定了默认的几个级别:trace

        这里要说明一下:

        1)级别之间是包含的关系,意思是如果你设置日志级别是trace,则大于等于这个级别的日志都会输出。

        2)基本上默认的级别没多大区别,就是一个默认的设定。你可以通过它的API自己定义级别。你也可以随意调用这些方法,不过你要在配置文件里面好好处理了,否则就起不到日志的作用了,而且也不易读,相当于一个规范,你要完全定义一套也可以,不用没多大必要。

        ALL:最低等级的,用于打开所有日志记录。

        TRACE(追踪): 就是程序推进一下,你就可以写个trace输出,所以trace应该会特别多,不过没关系,我们可以设置最低日志级别不让他输出。

        DEBUG: 指出细粒度信息事件对调试应用程序是非常有帮助的,主要用于开发过程中打印一些运行信息。

        INFO: 消息在粗粒度级别上突出强调应用程序的运行过程。打印一些你感兴趣的或者重要的信息,这个可以用于生产环境中输出程序运行的一些重要信息,但是不能滥用,避免打印过多的日志。

        WARN: 表明会出现潜在错误的情形,有些信息不是错误信息,但是也要给程序员的一些提示。

        ERROR: 指出虽然发生错误事件,但仍然不影响系统的继续运行。打印错误和异常信息,如果不想输出太多的日志,可以使用这个级别。

        FATAL: 指出每个严重的错误事件将会导致应用程序的退出。这个级别比较高了。重大错误,这种级别你可以直接停止程序了。

        OFF: 最高等级的,用于关闭所有日志记录。

        如果将log level设置在某一个级别上,那么比此级别优先级高的log都能打印出来。

        例如,如果设置优先级为WARN,那么OFF、FATAL、ERROR、WARN 4个级别的log能正常 输出,而INFO、DEBUG、TRACE、 ALL级别的log则会被忽略。Log4j建议只使用四个级别,优先级从高到低分别是ERROR、WARN、INFO、DEBUG

        log4j默认的优先级为ERROR或者WARN(实际上是ERROR)。

        Level.ALL开启所有的级别记录。或者使⽤Level.OFF关闭所有的级别记录。

        Log4j建议只使⽤四个级别,优先级从⾼到低分别是ERROR、WARN、INFO、DEBUG。

SLF4J的日志级别

        SLF4J将日志分为:trace、debug、info、warn、error五个级别

        每个级别对应记录不同的日志,对应不同的使用场景。
        优先级从高到低依次为:trace、debug、info、warn、error,相对而言,打印的日志会越来越少。

        trace: 一般用来追踪详细的程序运行流,比如程序的运行过程中,运行到了哪一个方法,进入了哪一条分支。通过trace程序的运行流程,可以判断程序是否按照期望的逻辑在运行。
        debug: 这类日志往往用在判断是否有出现bug的场景,且往往记录了代码运行的详细信息,比如方法调用传入的参数信息。
        info:用来记录程序运行的一些关键信息,它不像trace那样记录程序运行的整个流程,也不像debug那样为了解决问题而记录详细的信息。info记录的是整个系统的运行信息,比如系统运行到了哪一个阶段,到达了哪一个状态。
        warn:用来记录一些警告信息。警告信息表示,程序进入了一个特殊的状态,在该状态下程序可以继续运行,但是不建议让程序进入该状态,因为该状态可能导致结果出现问题。
        error:用来记录运行时的错误信息,表示程序运行过程中出现了需要被解决的问题,往往是一些异常。使用error日志的时候,一般会将详细的异常出现的原因记录。

你可能感兴趣的:(Java,java,log4j,开发语言)