Java日志记录的5条规则
作者:网络转载 发布时间:[ 2015/12/31 10:23:18 ] 推荐标签:编程语言 测试开发技术
日志记录是在软件开发过程中常常需要考虑的关键因素。
当产品运行出错时,日志文件通常是我们进行错误分析的首要选择。
而且,在很多情况下,它们是我们手上可以用来查明发生状况和问题根本原因的信息。
可见,正确记录需要的信息是极其重要的。
以下5条日志规则,让我们可以检查和改进在代码中操作日志记录的方式。
同时也请注意,我们既不会讨论怎么配置一个日志引擎,也不会相互比较。
规则1、日志是面向读者的
日志消息不仅要对书写(日志)代码的人有意义,也应该对日志文件的读者有意义。
这似乎是一条很明显但却经常违背的规则。
ERROR: Save failure - SQLException .....
举个例子吧,我们来看看下面这条日志信息:
ERROR: Save failure - SQLException .....
保存什么呢?这条消息在开发者看来是能说明一些问题的,但是对于正在苦苦查看产品问题的可怜家伙来说,却毫无用处。
RROR: Save failure- Entity=Person, Data=[id=123 surname="Mario"] - SQLException....
更合适的信息是这样的:
RROR: Save failure- Entity=Person, Data=[id=123 surname="Mario"] - SQLException....
这解释了你想要存储的东西(这里是一个 Person,是一个 JPA 实体)以及这个 Person 实例相关的内容。
请注意相关这个单词,并不是指泛泛的全体:我们不应该让无价值的信息使日志文件变得乱糟糟,比如说完整打印所有的实体字段。
通常,实体名字和其逻辑关键字足以识别在表格中的一条记录了。
规则2、匹配日志等级和执行环境
在 Java 系统中提供的所有日志管理工具和引擎都有日志等级(ERROR、INFO……)的概念,这将有可能过滤掉等级过低的消息。
例如,Java util logging 使用如下的等级:SEVERE、WARN、INFO、FINE、FINER、FINEST(+ CONFIG 和 OFF)。相反,两个受欢迎的日志管理工具, Apache Commons Logging 和 SLFJ 更倾向于如下的等级:FATAL、ERROR、WARN、INFO、DEBUG、TRACE。
日志过滤等级则需要取决于代码的开发阶段:成品与仍处在测试、集成环境下的代码日志等级不能相同。
更具体的来说,日志等级也应该参考代码的归属情况。
一般而言,我们自己的应用程序代码应该比使用的任何第三方开发库拥有更详细的日志记录。
比如说,Apache 的通用调试消息出现在我们的日志文件中,没有多大意义。
我通常像这样配置日志记录:
成品阶段: 我的代码是 INFO 等级,第三方库是 WARN。
测试、集成阶段:我的代码是 DEBUG 等级,第三方库是 WARN(或者如果需要的话是 INFO)。
开发阶段:任何有意义的信息。
注意:个人而言,我不建议使用 TRACE/FINEST 等级(我并不是持这种观点的人,可以参考 这里 的例子)。
我并没有发现 DEBUG 和 TRACE 有多大的区别,而年轻团队的成员常常苦恼于到底是使用 DEBUG 还是 TRACE 。
根据 KISS 原则,我建议只使用 RROR、WARN、INFO 和 DEBUG 等级。
规则3、提交前去除编码帮助日志
编码时,我们常常会使用 logger 或是 System.out 在代码中添加日志消息,来更好地掌握应用程序在执行、调试期间发生的状况。
void aMethod(String aParam) {
LOGGER.debug(“Enter in aMethod”);
if (“no”.equals(aParam)) {
LOGGER.debug(“User says no”);
….
比如这样的代码:
void aMethod(String aParam) {
LOGGER.debug(“Enter in aMethod”);
if (“no”.equals(aParam)) {
LOGGER.debug(“User says no”);
….
这些消息显示被调用的方法并且备份内部变量及方法参数值,主要是为了追踪应用程序的行为。这在非测试驱动开发中相当受欢迎。
但糟糕的是,一旦代码发布(测试之后成为成品)这些消息通常无用武之地了。
所以,这条规则简单来说是:一旦你已经完成开发工作,在将代码提交到使用中的 SCM 系统(git、svn……)之前,要去除所有临时的和不必要的日志消息。
这条规则并不是要求去除所有的 DEBUG 消息,只是针对那些在应用程序完成和发布后没有意义的消息,或者是说当我们有理由相信应用程序能正确运行时失去意义的那些消息。
相关推荐
更新发布
功能测试和接口测试的区别
2023/3/23 14:23:39如何写好测试用例文档
2023/3/22 16:17:39常用的选择回归测试的方式有哪些?
2022/6/14 16:14:27测试流程中需要重点把关几个过程?
2021/10/18 15:37:44性能测试的七种方法
2021/9/17 15:19:29全链路压测优化思路
2021/9/14 15:42:25性能测试流程浅谈
2021/5/28 17:25:47常见的APP性能测试指标
2021/5/8 17:01:11