spring-boot笔记--日志

三、Spring Boot日志

1、日志框架

日志的抽象层:JCL、SLF4J、jboss-logging

日志的实现:Log4j JUL、Log4j2 Logback

Spring Boot:底层是Spring、Spring默认是JCL、而Spring Boot选用SLF4j和logback

2、SLF4j

2.1 系统中如何使用

开发的时候,日志记录方法的调用应该调用日志抽象层的方法

首先导入slf4j的jar和logback的jar,可以查看下图

抽象层到框架的方法--来自slf4j官网
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("Hello World");
  }
}

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

2.2 多个日志框架统一转成slf4j

如何让系统中所有的日志统一到slf4j

多个框架统一到slf4j的方法--来自slf4j官网
  1. 首先将系统的其它日志框架排除
  2. 用中间包来替换原来的日志框架
  3. 导入slf4j来实现统一框架

2.3 Spring Boot日志关系

我们可以创建一个新的项目,在pom.xml文件右键点击Diagrams-->Show Dependencies,可以看到idea为我们画好的依赖图

其中spring-boot-starter是我们最基本的文件

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter</artifactId>
    <version>2.2.2.RELEASE</version>
    <scope>compile</scope>
</dependency>

Spring Boot使用它来做我们的日志功能

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-logging</artifactId>
    <version>2.2.2.RELEASE</version>
    <scope>compile</scope>
</dependency>

我们可以在依赖图下查看我们的依赖关系,可以看到spring-boot-starter-logging依赖logback-classic来使用logback进行日志记录,其它还有xxx-to-slf4j来将其它的日志框架转换为slf4j

Spring Boot底层也是使用slf4j+logback的方式来进行日志记录,Spring Boot也把其它的日志也转换成slf4j,如果我们要用其它日志框架,一定要把日志的框架依赖移除掉,Spring Boot能自动适配所有的日志,而且底层使用slf4j+logback的方式记录日志

2.4 Spring Boot日志的使用

  1. 默认配置

    Spring Boot帮我们配置好了日志

    Logger logger = LoggerFactory.getLogger(getClass());
    
    @Test
    void contextLoads() {
    
        //日志的级别trace<debug<info<warn<error
        //我们可以自己调整输出的级别
     //Spring Boot默认使用的是info级别的,只输出info、warn、error
        logger.trace(() -> "trace");
        logger.debug(() -> "debug");
        logger.info(() -> "info");
        logger.warn(() -> "warn");
        logger.error(() -> "error");
    }
    
  2. 改变配置

    在application.properties里写入

    logging.level.com.包名=trace
    

    可以更改日志级别,没有指定就用Spring Boot默认指定的级别,root级别

    # 会在根目录下生成spboot.log
    logging.file.name=spboot.log
    # 制定完整的路径,可在对应路径下找到
    logging.file.name=G:/spboot.log
    # 在指定路径下创建spring.log,/splog/log是在所在磁盘根目录下创建,name和path同时指定name起作用
    logging.file.path=G:/splog/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
    
    日志的输出格式:
     %d:表示日期和时间
     %thread:表示线程的名字
     %-5level:表示级别从左显示5个字符宽度
     %logger{50}:表示logger名字最长为50个字符,否则按照句点分割
     %msg:日志消息
     %n:换行
    
  3. 指定配置

    如果我们要用自己的配置,那么在类路径下放上每个日志框架自己的配置文件,然后Spring Boot就不会使用自己的配置了

    官方文档

    Logging System Customization
    Logback logback-spring.xml, logback-spring.groovy, logback.xml, or logback.groovy
    Log4j2 log4j2-spring.xml or log4j2.xml
    JDK (Java Util Logging) logging.properties

    logback.xml直接被日志框架识别

    logback-spring.xml由Spring Boot加载配置项

    <springProfile name="staging">
        <!-- configuration to be enabled when the "staging" profile is active -->
        <!-- 可以指定在某个环境下生效 -->
    </springProfile>
    
    <springProfile name="dev | staging">
        <!-- configuration to be enabled when the "dev" or "staging" profiles are active -->
    </springProfile>
    
    <springProfile name="!production">
        <!-- configuration to be enabled when the "production" profile is not active -->
    </springProfile>
    

2.5 Spring Boot日志框架的切换

可以按照官网的适配图进行切换,可以查看2.2下的图片,我们可以通过生成依赖图的方式对依赖进行管理,具体引入哪些依赖可以查看官方文档,删除哪些依赖可以查看2.2下的图片

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

推荐阅读更多精彩内容

  • Sublime 自带格式化功能(代码缩进), 在menu->edit->line->reindent 但是没有快捷...
    HaRun阅读 1,792评论 0 0
  • 文/奋斗一直在一路上 黎明的钟声还未彻底敲响,打开窗帘的那刹那,外面一片漆黑,整个城市和大地还在熟睡之中。 我穿好...
    慕容兰馨阅读 465评论 12 30
  • 这是之前在梦想小镇散步时偶然拍到的移动式酒店,第一眼看到的时候就被吸引过去了。 看上去就像一节车厢,整体构造也具有...
    黎晓雪漫阅读 385评论 0 0
  • 何以诚阅读 170评论 0 0