日志的粒度请教?

2019-08-06 16:35:57 +08:00
 chaleaochexist
不会打 log.
不知道哪些地方需要打 log.

目前的情况是总是丢 log.
线上的一些随机问题不知道是哪些地方引起的.

但是 log 太细,又觉得不太合适吧?

请教最佳实践.谢谢.
2947 次点击
所在节点    程序员
12 条回复
VANHOR
2019-08-06 16:39:58 +08:00
看看楼下怎么说
maemual
2019-08-06 16:40:36 +08:00
当遇到问题的时候你想知道哪些信息有助于你解决问题
lihongjie0209
2019-08-06 16:41:39 +08:00
遇到问题就加上, 加多了就有经验了
jsjscool
2019-08-06 16:49:40 +08:00
第三方的接口调用要打,服务的输入输出要打,其他的能不打就不打。写日志是帮助自己用最少的字符得到最有用的结论。
arrow8899
2019-08-06 16:53:35 +08:00
只在关键的地方记日志,服务调用请求和响应记日志,这样出现问题可以根据代码一步一步复现。
mushishi
2019-08-06 16:57:48 +08:00
## 场景 1. 判断程序中关键方法是否进入与正常退出。
3. 固定:类名+方法名+start+关键参数用于过虑日志

## 场景 2:判断关键方法内部逻辑是否正常进入和退出。
2. 固定:类名+方法名+逻辑主要功能名+start/end+关键参数用于过虑日志

## 场景 3:判断程序异常执行关键日志,及异常输出,如果是符合预期的异常捕获可以使用 wran 级别代替 error。
1. 固定:类名+方法名+[逻辑主要功能名]+got exception error+[关键参数用于过虑日志]+e.getMessage []中括号中的信息代码位置视情况需不需要加
mushishi
2019-08-06 16:59:28 +08:00
@mushishi 我们团队内部暂时使用的日志规范
pkookp8
2019-08-06 17:04:41 +08:00
用等级区分,不重要的或只是协助看流程的 debug 或 trace
出了问题用于快速定位问题区间的 info
意料外的但是能处理的 warn
无法恢复或不能简单处理的,error 或 critical
外部封装,内部 if 或 switchcase,一句判断条件语句不影响性能(影响的地方用 flag 或 count 记录,别的线程定时输出)
stevenkang
2019-08-06 17:12:24 +08:00
总结了以下几点:

1、API 的 I/O 日志,也就是请求参数和响应内容记录日志,这相当于整个系统的大门了,访问日志在排错、性能分析等方面非常有用;

2、第三方 API 的 I/O 日志,也就是请求第三方 API 发送了哪些参数,第三方 API 又响应了哪些参数,这有利于分析传递的数据是否正确;

3、异常块,所有捕获异常的位置均应当记录异常内容,除非一些用于业务逻辑判断的异常块(例如:利用异常来判断某个字符串是否能转换等);

4、非正常请求,例如请求某个 API 报了 403,应当记录 >= WARN 级别的日志,这里和 #1 的区别是,#1 无论正常还是异常均记录请求、响应内容,这里的应当记录更加详细的内容,例如为什么会产生 403 响应,并且日志级别应当更高,方便分析、优化;

5、应用启停日志,在启动应用进行初始化时,应当记录各个参数的情况,便于在启动时遇到问题进行定位。同理,在应用停止的时候(特别是异常停止),应当记录详细的运行状况、运行参数等日志;

6、其他日志,根据实际业务情况需要,应当记录其他日志,例如调用短信接口时记录短信用量、剩余量等,这样可以通过编写日志报警规则来实现短信余额不足预警功能;
jatsz
2019-08-06 17:15:36 +08:00
这个是个好问题,我在自己的一篇博客中总结过: https://www.imzjy.com/blog/2018-07-06-writing-good-log

通常下面的情况可以考虑加一行日志:

- 程序的参数检查一下,函数输入决定输出,输入都不对,输出怎么可能对呢?
- 第三方回传的时候检查一下,返回数据了么,返回大小是多少,调用时间用了多少?
- 关键业务点,留下点脚印,打一些 Info 类的日志。
- 有副作用的函数,比如操作网络,操作磁盘,数据库操作,有时候越是难的 bug,越是这些觉得不可能出错的地方出错。
- 应用程序启动相关的,比如加载的模块,影响行为的配置文件,环境变量,等等。
- 数据驱动着应用,常常 bug 在数据中。加一些日志在已有的数据上,即使不记录具体内容,也要记一下大小。
- 别在同一个地方跌倒两次。抓到一个 bug,或者业务漏洞修复,写个测试区覆盖或许很难,但是记一行日志不费多少电。
bulbzz
2019-08-06 22:07:05 +08:00
你觉得有问题的地方加上就可以了 粒度是可以准确定位出问题所在。
bravoer
2019-08-08 12:15:49 +08:00
打日志,一定要注意要形成一个完整的链,从开始到结束,让别人从你的日志中就可以整天程序运行的整个流程,完整清晰的流程一般是一个流程图,分支进入什么的都要考虑到,整个流程一般使用 info,异常使用 error,用于调式什么的,使用 trace 或者 debug。

你需要明确一点就是,打日志的作用在哪。你就知道怎么打了。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/589543

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX