选择哪一种日志框架

市面上日志门面有:

JCL(Jakart Commons Logging)SLF4J(Simple Logging Facade For Java)jboss-logging

日志实现有:

Log4JJUL(java.util.logging)Log4j2Logback

日志门面就是抽象接口,日志实现,就是具体的日志实现;

在日志接口中,jboss-logging 首先排除,它生来就不给我们普通程序员用的;接着排除掉 JCL,虽然它很好,也是 Apache 下面的项目,但是上一次更新还是 2014 年,辉煌也只属于过去了;

最后剩下了 SLF4J ,虽然它名字叫简陋的日志门面,但是这仅仅是作者的谦虚,这个日志门面一点都不简陋;

选好了日志门面,再选日志实现,首先排除 JUL ,它只是 Log4j 初出江湖,然后名震江湖之际,java 怕丢失日志市场,就推出了 JUL

然后再说下 Log4JLogback 其实它们是同一个作者写的,包括我们之前选的日志门面 SLF4J 也是出自同一人之手,大神的世界不是很懂;

然后 Log4j 是初级版本,大神后来加入了重大更新,有了 Logback ,因此 Logback 才是与 SLF4J 最切合的,毕竟出自同门;

为什么不选 Log4J2 ,它也是对 Log4J 的升级版,同样系出名门,来自 Apache小组,但是升级的太好了,以至于目前,还没有配得上它的日志门面。。。扎心了

Spring Boot 底层是 Spring 框架,Spring 框架默认使用的是 JCL,因此,之前使用 Spring 的时候,总是需要导入 Commons-Logging 日志框架 ;

Spring Boot 明智的选择了和我们分析的一样的 SLF4J + Logback 组合 ;


日志的使用

开发的时候,应该调用日志门面的方法,而不应该调用日志具体实现的方法,面向接口编程;

但是每一个日志实现框架都有自己的配置文件,在使用 SLF4J 的时候,日志配置文件还是使用具体日志实现框架的配置文件 ;

  1. 使用 SLF4J + Logback

    它们是天生就切合的;但是如果你日志实现不是使用 Logback呢,而是使用其他日志实现,那么 SLF4J 官方也提供了对应的 jar 包,进行适配;

    适配的原理就是,提供了一个适配层,比如你调用 SLF4J 的某个方法,然后通过适配层翻译为对应日志实现框架的方法;

  2. 历史遗留问题

    我们在项目开发的时候,使用许多第三方框架,SpringHibernate 等等,它们各自都有自己依赖的日志框架;

    我们如何最后统一使用 SLF4J + LogbackSLF4J 官方同样也提供了对应的 jar 包,具体的原理是这样的:比如 Spring 依赖 Commons-logging 那么,首先先去掉 Commons-logging ,去掉以后,Spring 启动就会保错,因为找不到需要的日志类,这时候将官方提供的替换包,添加进去,这个替换包起到偷梁换柱的作用,Commons-logging 包里面有的类,替换包都有,这样 Spring 启动的时候,就能找到对应的类了,但是这些类里面,都被动了手脚,里面都是去调用 Logback 的方法了;

    这样做以后,就能统一使用 SLF4J + Logback


Spring Boot 日志使用

使用其他框架的时候,需要移除框架本身依赖的日志框架;

至于 Spring 框架,Spring Boot 已经默认移除了 Commons-logging

如果是使用 SLF4J + Logback 则不需要导入任何包,Spring Boot 默认已经集成了 ;

 		// 记录器(导包不要导错了,导 slf4j)
Logger logger = LoggerFactory.getLogger(this.getClass()); // 打印的日志,只会打印设定的级别及其之后的级别日志
logger.trace("这是 trace 日志 ...");
logger.debug("这是 debug 日志 ...");
// Spring Boot 默认给我们使用的级别是 info ,
logger.info("这是 info 日志 ...");
logger.warn("这是 warn 日志 ...");
logger.error("这是 error 日子 ...");
  1. logging.level

    如果我们想更改默认的日志级别,可以在配置文件里面进行设置:

    logging:
    level:
    cn:
    hyc: trace

    其中 logging.level 用于控制日志级别,可以直接在后面写级别,如果想控制的细致点,可以在后面写上具体的包 ;

  2. logging.file + logging.path

    指定日志文件名字和日志文件保持路径;

    如果都没有指定,则只在控制台打印;

    但是这两个又是冲突的指令,当二者都存在的时候,只有 logging.file 起作用 ;

    使用 logging.file ,如果只指定了文件名,则在当前项目目录下,生成日志文件;当然也是可以指定具体路径的,比如下面的,就会在 D 盘下面生成日志文件:

    logging:
    file: D:my.log

    一般只是使用 logging.path ,仅仅制定路径,日志文件的名字使用 Spring Boot 默认的 名字 Spring.log

    logging:
    path: /spring/log

    这里 / 代表项目所在盘符的根目录 ;

  3. logging.pattern.console

    指定在控制台输出的日志的格式

  4. logging.pattern.file

    指定文件中日志的格式;

  5. 指定配置文件

    首先 Spring Boot 有自己默认的日志配置,如果我们不想用,想用自己的配置,则

    根据自己选择的日志实现框架,来命名自己的日志配置文件:

    比如,博主选择的是 Logback 日志实现,则日志配置文件的名字,可以是 logback-spring.xml, logback-spring.groovy, logback.xml, or logback.groovy 中的任何一个;

    把日志配置文件放在类路径下面,即可被 Spring Boot 自动加载 ;

    但是官方建议我们使用 logback-spring.xml 这样带后缀名的,而非直接使用 logback.xml ,因为 logback.xml 可以被日志框架直接识别,直接就加载了,Spring Boot 在此过程插不上手;

    如果使用 logback-spring.xml 这样的名字,日志框架就不认识,不会直接加载,而是由 Spring Boot 去解析日志配置,这样就可以使用高级Profile功能,比如:在配置文件的某项配置上,写<springProfile name = "dev> 这样,只有在特定环境下(dev 开发环境),该项配置才会生效;


(3)Spring Boot日志的更多相关文章

  1. Springboot 系列(四)Spring Boot 日志框架

    注意:本 Spring Boot 系列文章基于 Spring Boot 版本 v2.1.1.RELEASE 进行学习分析,版本不同可能会有细微差别. 前言 Spring 框架选择使用了 JCL 作为默 ...

  2. Spring Boot日志集成实战

    Spring Boot日志框架 Spring Boot支持Java Util Logging,Log4j2,Lockback作为日志框架,如果你使用starters启动器,Spring Boot将使用 ...

  3. Spring Boot 日志配置

    Spring Boot 日志配置 默认日志 Logback: 默认情况下,Spring Boot会用Logback来记录日志,并用INFO级别输出到控制台.在运行应用程序和其他例子时,你应该已经看到很 ...

  4. Spring Boot 日志记录 SLF4J

    Spring Boot 日志记录 SLF4J 2016年01月12日 09:25:28 阅读数:54086 在开发中打印内容,使用 System.out.println() 和 Log4j 应当是人人 ...

  5. Spring Boot日志集成

    Spring Boot日志框架 Spring Boot支持Java Util Logging,Log4j2,Lockback作为日志框架,如果你使用starters启动器,Spring Boot将使用 ...

  6. 让你的spring-boot应用日志随心所欲--spring boot日志深入分析

    1.spring boot日志概述 spring boot使用Commons Logging作为内部的日志系统,并且给Java Util Logging,Log4J2以及Logback都提供了默认的配 ...

  7. 54. spring boot日志升级篇—logback【从零开始学Spring Boot】

    在<44. Spring Boot日志记录SLF4J>章节中有关相关的介绍,这里我们在深入的了解下logback框架. 为什么要使用logback ? --在开发中不建议使用System. ...

  8. 52. spring boot日志升级篇—log4j多环境不同日志级别的控制【从零开始学Spring Boot】

    在上一章节中我们介绍了,仅通过log4j-spring.properties对日志级别进行控制,对于需要多环境部署的环境不是很方便,可能我们在开发环境大部分模块需要采用DEBUG级别,在测试环境可能需 ...

  9. 50. Spring Boot日志升级篇—log4j【从零开始学Spring Boot】

    如果你使用的是spring boot 1.4.0版本的话,那么你可能需要配合以下文章进行学习 90.Spring Boot 1.4 使用log4j错误[从零开始学Spring Boot] Log4j是 ...

  10. Spring Boot日志使用

    前言: 这是我第一次仔细研究Spring Boot相关的知识,就拿日志下手了,欢迎大家指点 Spring Boot日志关系 这个是Spring Boot的启动器,我们点击spring-boot-sta ...

随机推荐

  1. spark的一些基本概念和模型

    Application application和Hadoop MapReduce类似,都是指用户编写的spark应用程序,其中包含了一个driver功能的代码和分布在集群中多个节点运行的executo ...

  2. 两个对象key相同但是value不同,将value不同的键值对以对象形式输出

    let obj={ name:'jack', age:18, sex:'girl' } let obj2={ name:'rose', age:18, sex:'boy' } var str={} f ...

  3. c# 模拟并发请求 ,只能并发2个连接。

    使用 HttpWebRequest 模拟并发请求的时候,发现不管怎么提高thread 的数量,都没用,服务器端用计数器看到的都是2个连接,见下图(关于计数器怎么开,百度) 然后搜了一下,发现需要在ap ...

  4. Python中_,__,__xx__方法区别

    _xx 单下划线开头 Python中没有真正的私有属性或方法,可以在你想声明为私有的方法和属性前加上单下划线,以提示该属性和方法不应在外部调用.如果真的调用了也不会出错,但不符合规范. 方法就是以单下 ...

  5. [Linux] RTC 读写指令及测试程序

    CPU:RK3288 系统:Linux IC:hym8563 在 Linux 系统中,指令 date 和 hwclock 都可以读写时间 date:读写系统时间,写时间需要管理员权限 hwclock: ...

  6. C语言--二维数组

    一.PTA实验作业 题目1:7-2 求整数序列中出现次数最多的数 1. 本题PTA提交列表 2. 设计思路 定义变量n表示输入整数个数,count表示每个数出现次数,i.j表示循环变量,k表示次数最多 ...

  7. appium 多线程还是多进程(转)

    https://www.cnblogs.com/zouzou-busy/p/11440175.html 在前面我们都是使用一个机器进行测试,在做app自动化的时候,我们要测不同的机型,也就是兼容性测试 ...

  8. postgresql 字段sql语句 更改表名

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明.本文链接:https://blog.csdn.net/sq8706/article/detail ...

  9. DNGuard HVM Unpacker(3.71 trial support and x64 fixed)

    DNGuard HVM Unpacker(3.71 trial support and x64 fixed) Gr8 news. Finally got the x64 crash fixed. DN ...

  10. markdown2的key

    分享一个MarkDown2的授权key   邮箱地址: Soar360@live.com 授权秘钥: GBPduHjWfJU1mZqcPM3BikjYKF6xKhlKIys3i1MU2eJHqWGIm ...