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. 国产BI报表工具中低调的优秀“模范生”——思迈特软件Smartbi

    首先简单来介绍一下这位低调且优秀的模范生--思迈特软件Smartbi.思迈特Smartbi是企业级商业智能BI和大数据分析品牌,满足用户在企业级报表.数据可视化分析.自助分析平台.数据挖掘建模.AI智 ...

  2. java变量的初始化之后的默认值

    对于类的成员变量 不管程序有没有显示的初始化,Java  虚拟机都会先自动给它初始化为默认值. 1.整数类型(byte.short.int.long)的基本类型变量的默认值为0. 2.单精度浮点型(f ...

  3. Git如何使用,操作流程

    官方示例 git config --global user.name "sanqianll" git config --global user.email "224001 ...

  4. 为什么 Vue3.js / Element+ 组件属性前面有的需要添加冒号,有的不需要?

    背景 使用 Element+ Layout 布局: <el-row> <el-col :span="12"><div class="grid ...

  5. Redis-基本概念、java操作redis、springboot整合redis,分布式缓存,分布式session管理等

    NoSQL的引言 Redis数据库相关指令 Redis持久化相关机制 SpringBoot操作Redis Redis分布式缓存实现 Resis中主从复制架构和哨兵机制 Redis集群搭建 Redis实 ...

  6. winform中更新UI控件的方案介绍

    这是一个古老的话题...直入主题吧! 对winfrom的控件来说,多线程操作非常容易导致复杂且严重的bug,比如不同线程可能会因场景需要强制设置控件为不同的状态,进而引起并发.加锁.死锁.阻塞等问题. ...

  7. 用Vue编写一个简单的仿Explorer文件管理器

    ​大家一定很熟悉你桌面左上角那个小电脑吧,学名Windows资源管理器,几乎所有的工作都从这里开始,文件云端化是一种趋势.怎样用浏览器实现一个Web版本的Windows资源管理器呢?今天来用Vue好好 ...

  8. 从零开始,开发一个 Web Office 套件(9):拖动鼠标选中文字 Edge Case

    这是一个系列博客,最终目的是要做一个基于 HTML Canvas 的.类似于微软 Office 的 Web Office 套件(包括:文档.表格.幻灯片--等等). 博客园:<从零开始, 开发一 ...

  9. BSOJ6310题解

    互不相同,太困难啦!!!!!! 考虑可以相同的情况.可以容斥. \[ans=(1+1+1+1)-(2+1+1)+(3+1)+(2+2)-(4) \] 有点抽象,看看就好() \[ans=(a,b,c, ...

  10. LGP2891题解

    题目大意 有 \(n\) 只奶牛,\(q\) 种食物和 \(p\) 种饮料,每只奶牛喜欢一些饮料和食物,但只能那一种,求最小配对数量. 首先来看一下这道题的简化版:没有饮料,该怎么做呢? 我会!裸的二 ...