最简日志打印规范(推荐,转载)

我的认为,若是在公司的野蛮生长阶段,一些基础类库不作约束,极可能“埋坑”,造成技术债务,最终为此付出代价。本文讲解一个最简的日志打印规范。
事实上,日志打印规范互联网上已有不少,但大多比较冗长(记不住),也不太契合咱们团队(关注点不契合)。java

因此,我又造了个轮子,写了个简单易懂、容易记的“最简日志打印规范”,后续随着团队实力的增加,和项目的演进,会逐步增长新的条例。编程

1. 日志打印组件

日志组件有不少,日志门面的选择有:Slf4j、Apache Commons Logging等。数组

日志的实现更多,有:log4j、logback、log4j二、Java Util Logging(jul)、Jboss Logging等。less

目前,咱们使用Slf4j做为日志门面,logback做为日志实现性能

2. 日志打印级别

日志的级别有不少,咱们通常只用四个。日志级别由低到高DEBUG - INFO - WARN - ERROR。ui

  • DEBUG(调试):开发调试日志。通常来讲,在系统实际运行过程当中,不会输出该级别的日志。所以,开发人员能够打印任何本身以为有利于了解系统运行状态的东东。不过不少场景下,过多的DEBUG日志,并非好事,建议是按照业务逻辑的走向打印。打个比方,打印日志就像读书时划重点,若是导出都是重点,也就失去了重点。
  • INFO(通知):INFO日志级别主要用于记录系统运行状态等关联信息。该日志级别,经常使用于反馈系统当前状态给最终用户。因此,在这里输出的信息,应该对最终用户具备实际意义,也就是最终用户要可以看得明白是什么意思才行。
  • WARN(警告):WARN日志经常使用来表示系统模块发生问题,但并不影响系统运行。 此时,进行一些修复性的工做,还能把系统恢复到正常的状态。
  • ERROR(错误):此信息输出后,主体系统核心模块正常工做,须要修复才能正常工做。 就是说能够进行一些修复性的工做,但没法肯定系统会正常的工做下去,系统在之后的某个阶段,极可能会由于当前的这个问题,致使一个没法修复的错误(例如宕机),但也可能一直工做到中止也不出现严重问题。
  • 3. 日志打印场景

    在咱们的系统中,不一样的日志级别的打印场景大体以下:spa

    4. 日志使用方式

    • 使用的API
    日志级别 打印场景
    DEBUG 调试日志。目前管理相对宽松,咱们暂时没有严格要求。
    INFO 业务日志。咱们用来记录业务的主流程的走向。
    WARN 警告日志。通常来讲,发生对整个系统没什么影响的异常时,能够打印该级别的日志。
    ERROR 错误日志。级别比较高,若是发生一些异常,而且任什么时候候都须要打印时使用。
             
             
             
             
    public static final Logger LOGGER = LoggerFactory.getLogger(MyRealm. class);

    咱们使用的日志门面是slf4j,使用时应面向接口编程,LOGGER/LoggerFactory应该都是slf4j的API。debug

    严禁直接使用日志实现包。缘由大体有两点,第一是面向接口编程更优雅,这点没必要说明;第二,举个例子,由于log4j已经几年不更新,老的项目可能使用了log4j,如今想要换用logback或者log4j2,如直接使用log4j的API,不利于选型更换与API的统一(固然,非要用也不要紧,有个log4j-over-slf4j的适配器。但接口不统一,总感受哪里不对劲)。调试

    • 禁止字符串拼接

    例如:日志

             
             
             
             
    LOGGER .debug( "当前用户是:" + user + ",传入参数是:" + userId);

    严禁使用字符串拼接的方式打印日志,可读性、可维护性都比较差。

    建议的写法以下:

             
             
             
             
    LOGGER.debug( "当前用户是:{},传入参数是:{},返回值是:{},用户信息:{}", a,b new Object[]{token, userId, userInfo, authcInfo});

    由于咱们使用的是Slf4j,Slf4j有占位符填充的功能。多个占位符可放在Object数组中。

    • 无需使用级别判断

    不优雅示例:

             
             
             
             
    if (LOGGER.isDebugEnabled()) {
    LOGGER .debug( "当前用户是{}", token);
    }

    之前,为了性能,咱们经常在打印日志以前判断一下。

    使用Slf4j后,咱们能够写成以下形式就OK了。

             
             
             
             
    LOGGER .debug( "当前用户是{}", token);

    固然,若是依然使用字符串拼接的方式,仍是得判断一下级别的。

做者: 周礼  原文地址:http://www.itmuch.com/work/simple-standard-log/
相关文章
相关标签/搜索