为什么要使用日志

在项目开发的过程中, 添加合适的日志是一个必不可少的过程,给程序添加合适的日志有以下两个好处。

可以通过查看日志的输出,了解程序的运行状况,判断程序是否按预期进行运行。

程序出现bug的时候,可以通过日志判断出现问题的原因,而不需要去做繁琐的排查。

如果没有合适的日志,程序的运行状态就像是一个黑盒,只能通过测试的手段去判断结果是否正确,而详细的运行细节只能通过debug的方式去查看。

在程序的测试阶段这么做当然没问题,但是项目上线之后呢?一旦线上程序出了问题,如何快速的定位问题产生的原因是非常重要的,只有快速定位到问题的原因并修复,才能够最大程度的减少损失。

线上的环境无法像测试阶段一样去debug,即使可以debug,重现程序出现问题的场景也需要慢慢的去摸索。这个时候,如果程序预先添加了合适的日志,将程序的运行状况记录下来,就可以给问题的排查提供线索,即使不能直接通过日志判断出问题,也能将问题排查的范围缩小,减少大量的问题排查时间。

SLF4J日志组件

SLF4J是Java程序开发中常用的日志管理组件,通过引入该类库,可以添加不同级别的日志,输出不同级别的信息。本篇文章对具体如何使用SLF4J将不作介绍,只讨论其定义的日志级别的使用场景。

SLF4J将日志分为trace、debug、info、warn、error五个级别,每个级别对应记录不同的日志,对应不同的使用场景。

trace

trace是最低优先级的日志,一般用来追踪详细的程序运行流,比如程序的运行过程中,运行到了哪一个方法,进入了哪一条分支。通过trace程序的运行流程,可以判断程序是否按照期望的逻辑在运行。举个例子,有以下代码段。

public class Car{

//点火

public void fire(){

log.trace("fire")

...

}

//踩离合

public void clutch(){

log.trace("clutch")

...

}

//挂档

public void gear(){

log.trace("gear")

...

}

//松刹车

public void looseBrake(){

log.trace("gear")

...

}

}

...

public void static main(String[] args){

Car car = new Car();

car.fire();

car.clutch();

car.gear();

car.looseBrake();

}

上面的代码创建了一个Car实例,并依次运行了fire、clutch、gear、looseBrake四个方法完成骑车的起步动作。在上述的代码中,使用trace来跟踪了这个流程,记录了程序运行的流程,根据trace的记录,可以判断程序是否按流程去运行了。

debug

debug是比trace高一级别的日志,该级别的日志就是用来debug用的。这类日志往往用在判断是否有出现bug的场景,且往往记录了代码运行的详细信息,比如方法调用传入的参数信息。还是以上面的代码为例,将gear方法稍微变动如下。

//挂档

public void gear(int gear){

log.trace("gear")

//记录档位

log.debug(gear)

...

}

假设运行的过程中出现了问题,为了定位问题的原因,可以使用debug级别的日志来记录档位,通过记录运行时传入的gear来判断是不是因为档位输入错误而导致Car起步失败。

info

info比debug高一级别,用来记录程序运行的一些关键信息,它不像trace那样记录程序运行的整个流程,也不像debug那样为了解决问题而记录详细的信息。info记录的是整个系统的运行信息,比如系统运行到了哪一个阶段,到达了哪一个状态。还是以车启动为例子,将启动的代码修改如下。

public void static main(String[] args){

Car car = new Car();

car.fire();

car.clutch();

car.gear(1);

car.looseBrake();

log.info("car is ready to run faster !");

}

可以看到,运行完looseBrake方法之后,使用info记录了车的状态,车已经完成了起步了,可以踩油门加速了。

warn

warn比info的级别更高,用来记录一些警告信息。警告信息表示,程序进入了一个特殊的状态,在该状态下程序可以继续运行,但是不建议让程序进入该状态,因为该状态可能导致结果出现问题。继续修改车启动的例子,将gear方法修改如下。

//挂档

public void gear(int gear){

log.trace("gear")

//记录档位

log.debug(gear)

if(gear > 1){

log.warn("gear "+ gear +" is too high !")

}

...

}

车启动的过程中如果以大于1档起步,就使用warn记录警告,告诉调用者不推荐这样使用,实际上2档起步也是可以的,但可能会出问题。

error

error级别的日志是最高优先级了,用来记录运行时的错误信息,表示程序运行过程中出现了需要被解决的问题,往往是一些异常。使用error日志的时候,一般会将详细的异常出现的原因记录。例如以下代码。

public void static main(String[] args){

Car car = new Car();

try{

car.fire();

car.clutch();

car.gear(1);

car.looseBrake();

}catch(Exception e){

log.error("run failed !",e.getCause())

}

log.info("car is ready to run faster !");

}

上面的代码捕获了起步时出现的异常,并记录了异常信息,这样一旦出现问题,就可以通过日志来定位。

以上就是笔者对于SLF4J定义的日志级别使用场景的一些理解,如果有什么不正确的地方,欢迎批评指正。

java slf4j日志级别_SLF4J日志级别以及使用场景相关推荐

  1. java slf4j日志框架_SLF4J - 日志框架 - 类库 - Java - 代码树

    JAVA简易日志门面(Simple Logging Facade for Java,缩写SLF4J),是一套包装Logging 框架的界面程式,以外观模式实现.可以在软件部署的时候决定要使用的 Log ...

  2. java slf4j 占位符_slf4j 占位符

    slf4j format 占位符使用{}. For example, MessageFormatter.format("Hi {}.", "there") 1 ...

  3. java slf4j日志级别_java - 在slf4j中设置运行时消息的日志级别 - 堆栈内存溢出

    ===============>>#1 票数:41 已采纳 使用slf4j无法做到这slf4j . 我想,缺少这个功能的原因是,几乎不可能为slf4j构建一个Level类型,它可以有效地映 ...

  4. java log4j基本配置及日志级别配置详解,java基础面试笔试题

    我总结出了很多互联网公司的面试题及答案,并整理成了文档,以及各种学习的进阶学习资料,免费分享给大家. 扫描二维码或搜索下图红色VX号,加VX好友,拉你进[程序员面试学习交流群]免费领取.也欢迎各位一起 ...

  5. Jmeter日志输出和日志级别设置

    Jmeter运行出现问题可以通过调整jmeter的日志级别定位问题,但运行测试时建议关闭jmeter日志,jmeter打印日志耗费系统性能. Jmeter日志默认存放在%JMeter_HOME%\bi ...

  6. Log4j.xml配置日志按级别过滤并将指定级别的日志发送到ActiveMQ

    为什么80%的码农都做不了架构师?>>>    在之前的一篇博客<Spring+Log4j+ActiveMQ实现远程记录日志--实战+分析>的评论中,有同学提到这种方式应 ...

  7. linux activemq 打印日志,Log4j.xml配置日志按级别过滤并将指定级别的日志发送到ActiveMQ...

    目标:将debug,info级别的日志输出到本地文件,将warn,error级别的日志输出到ActiveMQ. 说明:本文还是使用之前的两个项目:Product和Logging. 经过一番搜索后,发现 ...

  8. 如何定义日志消息的级别?详解日志的5个级别

    作者 | aib42 译者 | 刘嘉洋,无明 出处丨 高效开发运维 日志级别如何划分? 日志记录是软件开发的一个概念,几乎所有(可能并不是所有)软件都能从日志记录中获得很多好处.在开始一个大项目时,日 ...

  9. Go 学习笔记(54)— Go 第三方库之 uber-go/zap/lumberjack(记录日志到文件、支持自动分割日志、支持日志级别、打印调用文件、函数和行号)

    1. 简要说明 zap 是 uber 开源的 Go 高性能日志库,支持不同的日志级别, 能够打印基本信息等,但不支持日志的分割,这里我们可以使用 lumberjack 也是 zap 官方推荐用于日志分 ...

最新文章

  1. 干货!top白帽子 Gr36_ 手把手教你挖漏洞|2017 先知白帽大会
  2. outlook地址薄导入到FOXMAIL
  3. 如何用图表控件实现点击图例图标隐藏图表序列
  4. 基于Redis实现分布式部署单点登录
  5. ai如何做倒角和圆角_石材路沿石是如何倒角的?倒角费用是多少?路沿石质量标准?...
  6. 三角形最小路径和—leetcode120
  7. JsonUtils.java
  8. 几道web题简单总结
  9. java基础知识——面向对象基本概念
  10. mysqlfor循环中出错继续_Python学习笔记(循环)
  11. kvm虚拟化网卡、virbr0、网段修改
  12. 软件测试系统并发数,“并发用户数”、“系统用户数”和“同时在线用户数”之间的差别...
  13. linux下安装xgboost
  14. 计算机硬盘容量1t,硬盘1tb等于多少gb 硬盘容量计算公式
  15. JAVA Reflect反射详解
  16. php alt什么意思,img标签的alt属性是什么意思?
  17. 学 C 语言,最经典的书有这样几本
  18. dgraph部署和使用
  19. 强化学习(Reinforcement Learning)入门学习--01
  20. python实现求解最长公共子序列LCS问题

热门文章

  1. 使用SoftICE调试程序入门
  2. 如何用ArcGIS出一张标准中国地图?常见误区有哪些?
  3. 对设备的控制和远程控制方式
  4. JS中时间对象及其方法(春节倒计时练习)
  5. 基本步骤:转换IBM Lotus Notes应用程序以使用Lotus Notes 8 Java组件
  6. 华擎H97 Performance 1150主板板载千兆网卡手动从百兆切换千兆设置
  7. 【Axure视频教程】鼠标滚动缩放图片
  8. Windows上ffmpeg使用GPU硬件加速多路rtsp转HLS直播流
  9. Python科学计算summary
  10. 哪些大学计算机学术实力更强?计算机科学ESI前1‰学科出炉