SpringBoot教程(四)(日志框架)

                        日   志

                                                                                原创者:文思

一、日志框架

大型系统对日志的需求:

1、关键数据打印在控制台

2、框架记录系统的运行时关键信息

3、日志的异步模式、自动归档

4、更换框架,不希望重新修改之前相关的API

回忆了解JDBC—数据库库驱动设计理念:写一个统一的接口层,给项目中导入具体的日志实现即可,我们之前的日志框架都是实现的抽象层。

现有的日志框架:

左边选一个抽象层,右边选一个实现,不熟悉的就不选择了。

抽象层就剩下slf4j了

日志实现:logback(Logback和slf4j是同一个作者)

SpringBoot选用slf4j和logback

https://www.slf4j.org/  官方文档永远是最应该优先学习的资料

import org.slf4j.Logger;

import org.slf4j.LoggerFactory;

public class HelloWorld {

       public static void main(String[] args) {

            Logger logger = LoggerFactory.getLogger(HelloWorld.class);

            logger.info("HelloWorld");

        }

}

slf4j是抽象层,需要有实现,使用方式图示:

由上图看出,应用程序直接面向slf4j接口抽象层,抽象层下面是具体的不同的实现类。即红色部分也告诉我们slf4j是一个抽象层,需要有一个默认的实现类。红色框是slf4j和logback组合的使用方式。

每一个日志的实现框架都有自己的日志文件,使用slf4j后,配置文件还是所选的实现类本身的配置文件。

二、遗留问题

不同的系统使用了不同的日志框架,如:SpringBoot(slf4j+logback)、Spring(commons-logging)、Hibernate(jboss-logging),如何让系统中所有的日志都统一到slf4j,官网图示:

1、将系统中其他日志框架先排除出去;

2、用中间包来替换原有的日志框架;

3、我们导入slf4j其他的实现

Spring用的commons-logging ,SpringBoot用的slf4j+logback,SpringBoot就是这么做的。

三、SpringBoot日志分析

新建一个SpringBoot工程,查看pom中包的关系,如图:

重点看红色部分,SpringBoot使用spring‐boot‐starter‐logging作日志功能。看红色部分jar包的命名,to或者over可猜测出这是属于中间包,用来替换原有的日志框架。查看这些jar包:

static LogFactory logFactory = new SLF4JLogFactory();可以看到jcl包里的LogFactory已经偷梁换柱成了SLF4JlogFacoty了。

总结:

1)、SpringBoot底层也是使用slf4j+logback的方式进行日志记录

2)、SpringBoot也把其他的日志都替换成了slf4j;

3)、中间转换报

4)、如果我们要引入其它框架,一定要把这个框架的默认日志依赖移除掉,比如Spring框架用的commons-loggin,看pom全图:

四、SpringBoot日志的使用

1、日志级别

运行测试类:

@RunWith(SpringRunner.class)

@SpringBootTest

public classSpringbootdemo3ApplicationTests {

    Loggerlogger= LoggerFactory.getLogger(Springbootdemo3ApplicationTests.class);

    @Test

    public void contextLoads() {

       //日志级别由低到高

       logger.trace("this is trace log...");

       logger.debug("this is debug log...");

       logger.info("this is info log...");//默认级别

       logger.warn("this is warn log...");

       logger.error("this is error log...");

    }

}

显示:2018-07-2516:05:38.606  INFO 7212 --- [           main]c.w.d.Springbootdemo3ApplicationTests   : this is info log...

2018-07-2516:05:38.608  WARN 7212 --- [           main]c.w.d.Springbootdemo3ApplicationTests   : this is warn log...

2018-07-2516:05:38.608 ERROR 7212 --- [          main] c.w.d.Springbootdemo3ApplicationTests    : this is error log...

默认显示info级别(info级别及以下)

默认显示info级别(info级别及以下)。

在application.propertis中设置日志级别后运行:

2018-07-2516:07:32.406 TRACE 15620 --- [          main] c.w.d.Springbootdemo3ApplicationTests    : this is trace log...

2018-07-2516:07:32.412 DEBUG 15620 --- [          main] c.w.d.Springbootdemo3ApplicationTests    : this is debug log...

2018-07-2516:07:32.413  INFO 15620 --- [           main]c.w.d.Springbootdemo3ApplicationTests   : this is info log...

2018-07-2516:07:32.413  WARN 15620 --- [           main]c.w.d.Springbootdemo3ApplicationTests   : this is warn log...

2018-07-25 16:07:32.413 ERROR 15620 --- [           main]c.w.d.Springbootdemo3ApplicationTests   : this is error log...

trace级别及以下级别信息都显示了

trace级别及以下级别信息都显示了。

2、日志路径

# 不指定路径在当前项目下生成springboot.log日志

# 可以指定完整的路径:logging.file=G:/springboot.log

# 在当前磁盘的根路径下创建spring文件夹和里面的log文件夹,使用spring.log 作为默认文件:logging.path=/spring/log

# 在控制台输出的日志的格:logging.pattern.console=%d{yyyy‐MM‐dd}[%thread] %‐5level %logger{50} ‐ %msg%n

# 指定文件中日志输出的格式:logging.pattern.file=%d{yyyy‐MM‐dd} === [%thread]

=== %‐5level === %logger{50} ==== %msg%n

3、Spring的日志输出格式:

%d表示日期时间,

%thread表示线程名,

%‐5level:级别从左显示5个字符宽度

%logger{50}表示logger名字最长50个字符,否则按照句点分割。

%msg:日志消息,

%n是换行符

例如:%d{yyyy‐MM‐dd HH:mm:ss.SSS} [%thread] %‐5level %logger{50} ‐ %msg%n

4、指定配置

给类路径下放每个日志框架自己的配置文件即可,用来覆盖SpringBoot默认的各框架下的配置

logback.xml:直接就被日志框架识别了。

logback-spring.xml:日志框架就不直接加载日志的配置项,由SpringBoot解析日志配置,可以使用SpringBoot的高级Profile功能。比如:指定某段配置只在某个环境下(开发\生产)生效

强烈推荐使用logback-spring.xml这种方式。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,647评论 18 139
  • 作为Java开发人员,对于日志记录框架一定非常熟悉。而且几乎在所有应用里面,一定会用到各种各样的日志框架用来记录程...
    意识流丶阅读 13,921评论 0 13
  • 前言 今天来介绍下Spring Boot如何配置日志logback,我刚学习的时候,是带着下面几个问题来查资料的 ...
    OzanShareing阅读 1,042评论 0 2
  • Logback是log4j框架的作者开发的新一代日志框架,它效率更高、能够适应诸多的运行环境,同时天然支持SLF4...
    李2牛阅读 4,097评论 0 16
  • Spring Boot 日志 《Spring Boot 开发实战》—— 基于 Gradle + Kotlin的企业...
    光剑书架上的书阅读 1,738评论 1 10