sprint-boot 日志

 

市面上的日志框架;

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

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

==SpringBoot选用 SLF4j和logback;==

日志记录方法的调用,不应该来直接调用日志的实现类,而是调用日志抽象层里面的方法;

给系统里面导入slf4j的jar和 logback的实现jar

使用手册:http://www.slf4j.org/manual.html

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抽象日志框架进行输出

springBoot日志关系
            <groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>

SpringBoot使用spring-boot-starter-logging来做日志功能

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</dependency>

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

​2)、SpringBoot也把其他的日志都替换成了slf4j;
中间替换包如下:

==SpringBoot能自动适配所有的日志,而且底层使用slf4j+logback的方式记录日志,

引入其他框架的时候,只需要把这个框架依赖的日志框架排除掉即可;

排除的格式;

        <dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<exclusions>
<exclusion>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
</exclusion>
</exclusions>
</dependency>

使用日志

  • ERROR 错误信息
  • WARN 警告信息
  • INFO 一般信息
  • DEBUG 调试信息
  • TRACE 跟踪信息

默认配置

@SpringBootTest
class SpLoggingApplicationTests {
//记录器
Logger logger = LoggerFactory.getLogger(getClass());
@Test
void contextLoads() {
//日志的级别,由低到高trace debug info warn error
//调整输出日志级别,日志只会在这个级别或者以后的高级别打印
// //上线只能只想输出warn,和error级别的日志
logger.trace("只是日志");
logger.debug("这是debug日志");
//springboot 默认给我使用的使info级别,
//没有指定级别的就用springboot 默认规定的级别,root级别
logger.info("这是info信息");
logger.warn("这是warn日志");
logger.error("error rizhi "); } }

结果 :

因为设置的默认的logging.level是info所以debug和trance都没有显示出来
在配置文件里面设置就可以了,logging.level.com = debug ,必须在level后面还要加上路径

修改结果:

可以在application.properties里面修改日志配置

logging.level.com.quan.splogging=trace#指定那个包或者哪个类的输出日志级别
#不指定路径就在当前项目下生成springbot.log日志
#可以指定完整的路径名称
#logging.file.name=quan.log
#一般指定目录
#不指定磁盘,默认在所在磁盘的根路径下创建spring文件夹里面的log文件夹
#使用spring.log为文件名字
logging.file.path=E:/spring/log
#在控制台输出的日志格式
logging.pattern.console=%d{yyyy-MM-dd} [%thread] %-5level %logger{50} - %msg%n
#指定文件中的日志输出格式
logging.pattern.file==

列子:

logging:
level:
com: trace
pattern:
console: 时间:%d{yyyy~MM~dd=HH:mm:ss} 线程名字:[[%thread]] 详情:%msg%n

热:

时间:2020~08~06=15:02:22 线程名字:[[main]] 详情:Running with Spring Boot v2.3.2.RELEASE, Spring v5.2.8.RELEASE
时间:2020~08~06=15:02:22 线程名字:[[main]] 详情:No active profile set, falling back to default profiles: default
时间:2020~08~06=15:02:23 线程名字:[[main]] 详情:Initializing ExecutorService 'applicationTaskExecutor'
时间:2020~08~06=15:02:23 线程名字:[[main]] 详情:Started HuolalaApplicationTests in 16.355 seconds (JVM running for 17.283) 时间:2020~08~06=15:02:23 线程名字:[[main]] 详情:djdijdi
时间:2020~08~06=15:02:23 线程名字:[[main]] 详情:debugdebug
时间:2020~08~06=15:02:23 线程名字:[[main]] 详情:errorerror

logging.file.name和logging.file.path的区别:

 日志格式的内容修改含义:

    日志输出格式:
%d表示日期时间,
%thread表示线程名,
%-5level:级别从左显示5个字符宽度
%logger{50} 表示logger名字最长50个字符,否则按照句点分割。
%msg:日志消息,
%n是换行符

指定配置:

给类路径下放上每个日志框架自己的配置文件即可:SpringBoot就不适用默认配置了,

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

logback-spring.xml:日志框架就不直接加载日志的配置项,由SpringBoot解析日志配置,可以使用SpringBoot的高级Profile功能

没使用Profile的:

<configuration>
<!-- 设置日志输出的格式,以便后面使用root引用 -->
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<!-- encoders are assigned the type
ch.qos.logback.classic.encoder.PatternLayoutEncoder by default -->
<encoder>
<pattern>logbackyml %d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
</encoder>
</appender> <!-- logger的值可以不区分大小写 用于设置那个包的或者具体类的日志打印级别 -->
<logger name="com.quan.learning" level="INFO"/> <!-- Strictly speaking, the level attribute is not necessary since -->
<!-- the level of the root level is set to DEBUG by default. -->
<!-- root节点必须在appender下面,主要的作用就是,对appdender进行管理
需要哪个就加入哪个,
而且这里的日志级别是总级别,最低能够打出的日志级别,如果appender比他高就取高的
-->
<root level="INFO">
<appender-ref ref="STDOUT" />
</root>
</configuration>

            <springProfile name="dev">
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} ----> [%thread] ---> %-5level %logger{50} - %msg%n</pattern>
</springProfile>
<springProfile name="!dev">
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} ==== [%thread] ==== %-5level %logger{50} - %msg%n</pattern>
</springProfile>

如果使用logback.xml作为日志配置文件,还要使用springProfile那就会报错

切换日志框架:
可以按照slf4j的日志适配图,进行相关的切换;

排除所需要排除的,

添加所需要的东西

例子:SLF4j+log4j2

直接

直接exclusion spring-boot-starter-logging,然后加上要实现的

     <dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
<!--引入新的log实现框架达到SLF4j+log4j,不过一般都不需要,因为有bug-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-log4j2</artifactId>
<version>2.3.2.RELEASE</version>
</dependency>

配置:

logging:
level:
com: trace
pattern:
console: log4j2的日志===时间:%d{yyyy~MM~dd=HH:mm:ss} 线程名字:[[%thread]] 详情:%msg%n

结果:

log4j2的日志===时间:2020~08~06=16:22:47 线程名字:[[main]] 详情:Initializing ExecutorService 'applicationTaskExecutor'
log4j2的日志===时间:2020~08~06=16:22:47 线程名字:[[main]] 详情:Started HuolalaApplicationTests in 21.406 seconds (JVM running for 27.56) log4j2的日志===时间:2020~08~06=16:22:47 线程名字:[[main]] 详情:djdijdi
log4j2的日志===时间:2020~08~06=16:22:47 线程名字:[[main]] 详情:debugdebug
log4j2的日志===时间:2020~08~06=16:22:47 线程名字:[[main]] 详情:errorerror log4j2的日志===时间:2020~08~06=16:22:47 线程名字:[[SpringContextShutdownHook]] 详情:Shutting down ExecutorService 'applicationTaskExecutor'

spring-boot-learning 日志相关的更多相关文章

  1. Spring Boot 之日志记录

    Spring Boot 之日志记录 Spring Boot 支持集成 Java 世界主流的日志库. 如果对于 Java 日志库不熟悉,可以参考:细说 Java 主流日志工具库 关键词: log4j, ...

  2. Spring Boot系列——日志配置

    日志,通常不会在需求阶段作为一个功能单独提出来,也不会在产品方案中看到它的细节.但是,这丝毫不影响它在任何一个系统中的重要的地位. 为了保证服务的高可用,发现问题一定要即使,解决问题一定要迅速,所以生 ...

  3. 【spring boot】8.spring boot的日志框架logback使用

    在继续上一篇的Debug调试之后,把spring boot的日志框架使用情况逐步蚕食. 参考:http://tengj.top/2017/04/05/springbo 开篇之前,贴上完整applica ...

  4. Spring Boot默认日志logback配置解析

    前言 今天来介绍下Spring Boot如何配置日志logback,我刚学习的时候,是带着下面几个问题来查资料的,你呢 如何引入日志? 日志输出格式以及输出方式如何配置? 代码中如何使用? 正文 Sp ...

  5. Spring Boot与日志

    目录 1.日志框架 2.市面上的日志框架 2.1 下表行间无任何对应关系 2.2 日志门面:slf4j 2.3 日志实现:logback 2.4 Spring Boot怎么做的呢? 3.slf4j的使 ...

  6. Spring Boot 自定义日志详解

    本节内容基于 Spring Boot 2.0. 你所需具备的基础 什么是 Spring Boot? Spring Boot 核心配置文件详解 Spring Boot 开启的 2 种方式 Spring ...

  7. Spring Boot Log4j2 日志学习

    简介 Java 中比较常用的日志工具类,有: Log4j. SLF4j. Commons-logging(简称jcl). Logback. Log4j2(Log4j 升级版). Jdk Logging ...

  8. Spring Boot的日志配置

    一.配置logback日志 Spring Boot默认使用logback打印日志 需要增加依赖 <groupId>org.springframework.boot</groupId& ...

  9. [日志] spring boot + logback 日志输出配置

    一.输出日志到控制台 springboot有很多starter(参考starter)方便快速构建项目依赖组件,logback是springboot默认的日志组件,启动即可看到打印在控制台输出的info ...

  10. 携程Apollo(阿波罗)配置中心Spring Boot迁移日志组件,使用配置中心进行管理的思路

    说明: 1.Spring Boot项目默认使用logback进行日志管理 2.logback在启动时默认会自动检查是否有logback.xml文件,如果有时会有限加载这个文件. 3.那么如果是用配置中 ...

随机推荐

  1. Linux安装ms-office

    https://ittutorials.net/open-source/linux/installing-microsoft-office-in-ubuntu/

  2. SaaS平台是什么,为什么字节、腾讯等大厂都在抢相关人才

    SaaS平台很多人可能没听说是什么,但是从事TO  B公司的员工来说,SaaS平台应该都有所耳闻.从2016年开始,腾讯开始发力TO B算起,到处在挖TO B公司的骨干人才,而熟悉SaaS平台的人才竞 ...

  3. IDEA安装下载以及使用

    IDE 集成开发环境(IDE,Integrated Development Environment )是用于提供程序开发环境的应用程序,一般包括代码编辑器.编译器.调试器和图形用户界面等工具.集成了代 ...

  4. .NET 5+ 中已过时的功能

    从 .NET 5 开始,一些新标记为已过时的 API 使用 ObsoleteAttribute 上的两个新属性. ObsoleteAttribute.DiagnosticId 属性指示编译器使用自定义 ...

  5. 【C# TAP 异步编程】四、SynchronizationContext 同步上下文|ExecutionContext

    一.同步上下文(SynchronizationContext)概述 由来 多线程程序在.net框架出现之前就已经存在了.这些程序通常需要一个线程将一个工作单元传递给另一个线程.Windows程序以消息 ...

  6. 【windows 访问控制】十二、C#实操 主体 System.Security.Principal 案例

    案例1.主体(包含用户和组)和标识(用户名)的使用. PrincipalPolicy枚举:主体类型 分为window主体.未认证的主体和未分配主体GenericPrincipal.GenericIde ...

  7. Echarts图表类型

    每个系列通过 type 决定自己的图表类型: type: 'bar':柱状/条形图 type: 'line':折线/面积图 type: 'pie':饼图 type: 'scatter':散点(气泡)图 ...

  8. Python:对元组使用关键字in

    如果in的左边是个含有多个元素的元组对象 例如 ('a','b') in L 那么L在什么情况下,这个式子会输出True呢? 答案是,L中必须也有一个和想要查找的元组一模一样的元组才行,比如: L=[ ...

  9. 安装CentOS时,推荐的分区方案

    最佳分区设置取决于 Linux 系统的用途.

  10. kube-scheduler源码分析(3)-抢占调度分析

    kube-scheduler源码分析(3)-抢占调度分析 kube-scheduler简介 kube-scheduler组件是kubernetes中的核心组件之一,主要负责pod资源对象的调度工作,具 ...