日志到底该如何打印?

商务办公
最近在做新项目,一直在加班,期间遇到很多问题,我把一部分归类为设计原则的问题,当然,这里的设计原则不是特指那个SOLID五大原则,这里是指更广义的设计原则,不喜勿喷。

 [[376361]]

最近在做新项目,一直在加班,期间遇到很多问题,我把一部分归类为设计原则的问题,当然,这里的设计原则不是特指那个SOLID五大原则,这里是指更广义的设计原则,不喜勿喷。

今天,我们来看第一个问题: 日志到底该如何打印?

咋一看,这个问题很简单,其实不然,我随手写几个,您看看。

  1. log.error("xxxxx"); 
  2.  
  3. log.error(e.getMessage()); 
  4.  
  5. log.error("xxxxx", e.getMessage()); 
  6.  
  7. log.error("xxxxx {}", e.message()); 
  8.  
  9. log.error("xxxxx {}", e); 

好了,就随便写这么多,地铁上打字不太方便,您认为上面那些日志打印方式哪些是正确的?

实话说,没有正确的,全是错的。怎么样,是不是踩坑了,是不是给别人埋过这样的坑。

那么,怎么打印日志才是正确的呢?

如果您使用的是slf4j,那么,只有下面这一种是正确的:

log.error("xxxxx, userId={}, xxParam={}", userId, xxParam, e);

首先,打印日志必须带上上下文信息,比如,用户ID,关键参数,同时,如果是捕获异常里面打印的日志,必须把原来的e打印出来,否则,排查日志想死的心都有了。

比如,我最近就遇到一个同学,他把远程调用用一个try catch包着,并在catch中捕获了异常,打印了日志"远程调用错误xxx",呵呵,有一次请求失败,非要说远程调用失败,对方出错了,对方说我没收到请求呀,两人撕逼,最后找到我,我一看这代码,说了一句,把e打印出来再重新调用,结果可想而知,他自己空指针了,呵呵了。

再说回上面的打印方式,有的同学可能会质疑,前面引号里明明是两个大括号,后面却出现3个变量,确定这个e能打印出来?

你是在怀疑我吗?自己看源码去。源码中已经明确写了如果最后一个参数是Exception类型,就不会参与字符串格式化,会单独拿出来打印,同时,可以打印出堆栈信息。看源码去吧,我在地铁上,就不截图了。

你以为本篇文章就结束了吗?那你就错了。

有没有更优雅的日志打印方式呢?

我认为,最好的日志是以解决问题的方式打印日志。

怎么理解呢?

我们以服务注册为例,当注册中心地址不通的时候,我们能不能这样打印呢?

"从 112.112.112.112 到注册中心 113.113.113.113的网络不通,请检查注册中心是否启动,网络防火墙是否畅通,balabala"。

这样的方式就比较好,给使用者提供解决方案,你只要按着给出的方案排查一下,大概率就能解决了你的问题,这才是最优雅的打印姿势。

好了,今天的内容就到这里,嗐,差点坐过站。

本文转载自微信公众号「 彤哥读源码  」,可以通过以下二维码关注。转载本文请联系 彤哥读源码  公众号。

 

责任编辑:武晓燕 来源: 彤哥读源码
相关推荐

2020-07-14 14:40:05

激光喷墨打印

2021-03-04 09:11:57

日志开发打印

2022-05-16 10:59:46

GPIOLinux内核

2018-03-13 11:13:07

喷墨激光打印机

2022-06-14 21:14:18

5.5GAI数字化

2021-07-08 21:51:03

5G技术Wi-Fi 6

2019-08-20 09:16:39

6G网络1G

2024-01-25 18:00:56

微服务系统KafkaRabbitMQ

2022-02-23 21:08:53

数字4G5G

2011-07-28 20:32:51

2015-06-02 11:26:29

产品团队

2011-07-29 10:51:26

2020-06-02 14:40:42

5G边缘计算物联网

2020-12-30 09:00:00

安全工具攻击

2015-09-25 11:03:14

数据中心日志分析

2017-01-06 14:57:02

2009-04-24 08:26:02

Mobile Mark移动OS

2017-04-05 21:43:08

MQ互联网架构

2023-03-15 08:42:06

form表单设计接口

2021-07-19 18:05:46

网络安全APT攻击网络攻击
点赞
收藏

51CTO技术栈公众号