zoukankan      html  css  js  c++  java
  • logback:参数化日志打印

    经常能看到打印日志的时候,使用以下这种方式打印日志:

    logger.debug("the message is " + msg + " from " + somebody);

    这种打印日志的方式有个缺点,就是无论日志级别是什么,程序总要先执行 "the message is " + msg + " from " + somebody 这段字符串的拼接操作。当 logger 设置的日志级别为比 DEBUG 级别更高级别时,DEBUG 级别的信息不回被打印出来的,显然,字符串拼接的操作是不必要的,当要拼接的字符串很大时,这无疑会带来很大的性能白白损耗。

    于是,一种改进的打印日志方式被人们发现了:

    if(logger.isDebugEnabled()) { 
      logger.debug("the message is " + msg + " from " + somebody);
    }

    这样的方式确实能避免字符串拼接的不必要损耗,但这也不是最好的方法,当日志级别为 DEBUG 时,那么打印这行消息,需要判断两次日志级别。一次是logger.isDebugEnabled(),另一次是 logger.debug() 方法内部也会做的判断。这样也会带来一点点效率问题,如果能找到更好的方法,谁愿意无视白白消耗的效率。

    有一种更好的方法,那就是提供占位符的方式,以参数化的方式打印日志,例如上述的语句,可以是这样的写法:

    logger.debug("the message {} is from {}", msg, somebody);

    这样的方式,避免了字符串拼接,也避免了多一次日志级别的判断。

  • 相关阅读:
    做支付遇到的HttpClient大坑
    一个隐藏在支付系统很长时间的雷
    记一次自动恢复的支付故障
    从GopherChina 2019看当前的go语言
    记一次上线就跪的故障排查案例
    springboot 源码笔记
    计算多边形面积
    springboots Helloworld
    springboots 配置文件
    springboots 环境搭建
  • 原文地址:https://www.cnblogs.com/jybky/p/12204448.html
Copyright © 2011-2022 走看看