SpringBoot初识日志

1、市面上的日志框架:

JUL、JCL、Jboss-logging、logback、log4j、log4j2、slf4j…

日志门面(日志的抽象层) 日志实现
SLF4j 、Jboss-logging、JCL(Jakarta Commons Logging) Log4j JUL(java.util.logging) Log4j2 Logback

左边是抽象层,右边是他的实现

日志门面:SLF4J;

日志实现:Logback;

SpringBoot:底层是Spring框架,Spring框架默认是用JCL;

SpringBoot选用SLF4j和logback

2、SLF4j的使用

1、如何在系统中使用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以后,配置文件还是做成日志实现框架本身的配置文件。

统一日志记录

比如说在使用其他框架的时候,Spring使用的日志框架是Commons-logging,Hibernate使用的是Jboss-logging等等。

我们要想统一日志记录,就比如全部改成SLF4j和Logback日志框架组合,该怎样做?

这时的slfj已经帮我们想好了解决方案,

如果日志框架是Commons-logging,想转成slf4j的使用,首先要去掉原来的日志依赖Commons-logging,再导入jcl-over-slf4j.jar,这个jar里面含有Commons-logging的实现类,也包含了slf4j的整合,所以可以转为对slf4j抽象层的使用。其余的日志框架也都有对应替换的jar包,这里不进行一一解释。

总结:如何让系统中的所有日志都统一到slf4j

  1. 将系统中其他日志框架先排除去
  2. 用各个对应日志框架转为slf4j的中间jar包替换原有的日志框架
  3. 导入slf4j其他实现

3、SpringBoot日志关系

下图关系依赖是springboot2.2.4

总结:

  1. SpringBoot底层使用的slf4j+Logback的方式进行的日志记录

  2. SpringBoot也罢其他的日志都替换成了slf4j;

  3. 中间替换包例如 log4j-to-slf4j

它里面具体的操作还是对SLF4j的操作

  1. SpringBoot是Spring的一套快速配置脚手架,但是Spring内涵的日志框架是Commons-logging,在SpringBoot2.0+,SpringBoot并没有加载Spring的日志框架,直接使用slf4j日志作为统一,Logback是对slf4j抽象层的实现。

  2. 注意:如果要引入其他框架,一定要把这个框架的默认日志依赖移除掉。

    SpringBoot能自动适配所有的日志,而且底层使用slf4j+logback的方式记录日志,引入其他框架的时候,只需要把这个框架依赖的日志框架排除掉即可。

    4、日志的使用

    1、默认配置

    root级别就是默认的级别,springboot日志root级别是info。

    @Test
    public void contextLoads() {
    //记录日志
    Logger logger = LoggerFactory.getLogger(getClass());
    //日志的级别由低到高: trace<debug<info<warn<error;输出日志的时候只会输出当前日志级别及其以上的日志信息 logger.trace("logger trace level ...");
    logger.debug("logger debug level...");
    //springboot默认日志级别是info
    logger.info("logger info level...");
    logger.warn("logger warn level...");
    logger.error("logger error level..."); }


要想修改隔离级别

在application配置文件中设置,例如将日志默认级别设置成trace,最低的。

logging.level.cn.edu.nyist.springboot03logging=trace

cn.edu.nyist.springboot03logging是对应的项目名的路径

日志输出路径和日志输出文件如果都不在配置文件中指定,默认只会在控制台输出

logging.path=输出日志的指定路径

# 在当前根目录下创建spring和里面的log文件夹,默认日志文件名是spring.log
logging.path=/spring/log

logging.file=输出的日志文件名,也可以指定路径;例如logging.file=D:/springboot.log;指定输出到D盘的xxx.log文件,文件没有会自行创建,如果不指定路径就会在当前项目下创建日志文件。

#输出到文件中的日志格式
logging.pattern.file=%d{yyyy-MMM-dd HH:mm:ss.SSS} %-5level [%thread] %logger{15} - %msg%n #输出到控制台的日志格式
logging.pattern.console=%d{yyyy-MMM-dd HH:mm:ss.SSS} %-5level [%thread] %logger{15} - %msg%n

2、指定配置

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

直接在resources目录下创建日志配置文件,例如使用logback日志系统,创建logback.xml或者logback-spring.xml;

但是这两个有什么区别吗?

这里官方文档上推荐我们创建带spring的配置文件,因为这样可以使用SpringBoot的一些高级Profile功能,而logback.xml就不能使用,如果logback.xml使用了Profile功能,但是SpringBoot并不会解析它,所以就会报错。

ERROR in ch.qos.logback.core.joran.spi.Interpreter@4:71 - no applicable action for [springProperty], current ElementPath is [[configuration][springProperty]]
ERROR in ch.qos.logback.core.joran.spi.Interpreter@4:71 - no applicable action for [springProfile], current ElementPath is [[configuration][springProfile]]

Profile-specific Configuration功能

<springProfile name="dev">
<!-- configuration to be enabled when the "dev" profile is active -->
这里指定了接下来的配置在dev环境下执行 </springProfile>

切换日志框架

将logback切换成log4j2

  1. 先去掉相关依赖[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传在这里插入图片描述

  2. 添加log4j2相关依赖

     <dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
    <exclusions>
    <exclusion>
    <artifactId>spring-boot-starter-logging</artifactId>
    <groupId>org.springframework.boot</groupId>
    </exclusion>
    </exclusions>
    </dependency>
    <dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-log4j2</artifactId>
    </dependency>

SpringBoot初识日志的更多相关文章

  1. SpringBoot与日志框架2(日志内斗)

    一.SpringBoot如何引入slf4j+logback框架的呢? 在POM文件中 <dependency> <groupId>org.springframework.boo ...

  2. SpringBoot与日志框架1(基本使用)

    一.日志框架 1.无论在什么系统,日志框架都是一个重要角色,所以理解和用好日志框架是相当重要的:像JDBC一样,日志框架分为接口层的门面和具体的实现组成. 2.市面上的产品: 2.1门面:SLF4J( ...

  3. Springboot的日志管理&Springboot整合Junit测试&Springboot中AOP的使用

    ==============Springboot的日志管理============= springboot无需引入日志的包,springboot默认已经依赖了slf4j.logback.log4j等日 ...

  4. java框架之SpringBoot(3)-日志

    市面上的日志框架 日志抽象层 日志实现 JCL(Jakarta Commons Logging).SLF4J(Simple Logging Facade For Java).JBoss-Logging ...

  5. SpringBoot整合日志

    Java日志 日志的接口层.抽象层 日志的实现 JCL(Jakarta Commons Logging) SLF4J(Simple Logging Facade for Java) Jboss-Log ...

  6. SpringBoot的日志

    1.日志框架小张:开发一个大型系统:1.System.out.pringtln("");将关键数据打印在控制台:去掉?写在一个文件?2.框架来记录系统的一些运行信息:日志:zhan ...

  7. Springboot与日志

    日志框架 比如开发一个大型系统:1.System.out.println(""):将关键数据打印在控制台:去掉?写在一个文件?2.框架来记录系统的一些运行时信息:日志框架 :riz ...

  8. SpringBoot的日志管理

    SpringBoot的日志管理 SpringBoot关于日志的官方文档 1.简述 SpringBoot官方文档关于日志的整体说明 本博客基于SpringBoot_1.3.6大家请先简单看下这篇英文的官 ...

  9. springboot+logback日志输出企业实践(下)

    目录 1.引言 2. 输出 logback 状态数据 3. logback 异步输出日志 3.1 异步输出配置 3.2 异步输出原理 4. springboot 多环境下 logback 配置 5. ...

随机推荐

  1. ModelViewSet+ModelSerializer使用

    1.DRF初始化 DRF框架的8个核心功能 1.认证(用户登录校验用户名密码或者token是否合法) 2.权限(根据不同的用户角色,可以操作不同的表) 3.限流(限制接口访问速度) 4.序列化(返回j ...

  2. 二、TestNG的Hello World

    创建第一个TestNG的例子 1.创建一个TestNG的类 选择项目路径"右键"--NEW--Other 选择TestNG cLass(如果没有这个选项是testng没有配置成功) ...

  3. pag object设模式

    pag object 是自动化测试最佳模式测试之一,它主要体现在对界面交互细节的封装 优点: 减少代码重复,提高测试的可读性,提搞测试用例的可维护性.

  4. Spring中BeanFactory与FactoryBean到底有什么区别?

    一.BeanFactory BeanFactory是一个接口,它是Spring中工厂的顶层规范,是SpringIoc容器的核心接口,它定义了getBean().containsBean()等管理Bea ...

  5. Python的精髓居然是方括号、花括号和圆括号!

    和其他编程语言相比,什么才是Python独一无二的特色呢?很多程序员会说,缩进.的确,缩进是Python语言的标志性特点,但这只是外在的.形式上的.从语言特性层面讲,Python的特点是什么呢?我尝试 ...

  6. 学习JUC源码(3)——Condition等待队列(源码分析结合图文理解)

    前言 在Java多线程中的wait/notify通信模式结尾就已经介绍过,Java线程之间有两种种等待/通知模式,在那篇博文中是利用Object监视器的方法(wait(),notify().notif ...

  7. ASP.NET中二进制流下载文件时进度条的使用

    说明 在下载大文件时,页面会进入假死状态,于是加上一个进度条以标识后台程序正在运行. 目前,做的进度条并不是实时的,并不会根据程序执行的进度正确显示. 目前是将进度条定时加载到90%,然后停止,等待后 ...

  8. Linq基础知识

    开发人员不需要关心将要访问的是关系数据库还是XML数据,或是远程对象,它都采用同样的访问方式. Linq包含一系列的查询技术,其中Linq到对象是对内存进行操作,LINQ到SQL是对数据库的操作,LI ...

  9. Redis基础篇(五)AOF与RDB比较和选择策略

    RDB和AOF对比 关于RDB和AOF的优缺点,官网上面也给了比较详细的说明redis.io/topics/pers- RDB 优点: RDB快照是一个压缩过的非常紧凑的文件,保存着某个时间点的数据集 ...

  10. 深入浅出Mybatis系列 强大的动态SQL

    上篇文章<深入浅出Mybatis系列(八)---mapper映射文件配置之select.resultMap>简单介绍了mybatis的查询,至此,CRUD都已讲完.本文将介绍mybatis ...