spring-boot-learning 日志相关
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 日志相关的更多相关文章
- Spring Boot 之日志记录
Spring Boot 之日志记录 Spring Boot 支持集成 Java 世界主流的日志库. 如果对于 Java 日志库不熟悉,可以参考:细说 Java 主流日志工具库 关键词: log4j, ...
- Spring Boot系列——日志配置
日志,通常不会在需求阶段作为一个功能单独提出来,也不会在产品方案中看到它的细节.但是,这丝毫不影响它在任何一个系统中的重要的地位. 为了保证服务的高可用,发现问题一定要即使,解决问题一定要迅速,所以生 ...
- 【spring boot】8.spring boot的日志框架logback使用
在继续上一篇的Debug调试之后,把spring boot的日志框架使用情况逐步蚕食. 参考:http://tengj.top/2017/04/05/springbo 开篇之前,贴上完整applica ...
- Spring Boot默认日志logback配置解析
前言 今天来介绍下Spring Boot如何配置日志logback,我刚学习的时候,是带着下面几个问题来查资料的,你呢 如何引入日志? 日志输出格式以及输出方式如何配置? 代码中如何使用? 正文 Sp ...
- Spring Boot与日志
目录 1.日志框架 2.市面上的日志框架 2.1 下表行间无任何对应关系 2.2 日志门面:slf4j 2.3 日志实现:logback 2.4 Spring Boot怎么做的呢? 3.slf4j的使 ...
- Spring Boot 自定义日志详解
本节内容基于 Spring Boot 2.0. 你所需具备的基础 什么是 Spring Boot? Spring Boot 核心配置文件详解 Spring Boot 开启的 2 种方式 Spring ...
- Spring Boot Log4j2 日志学习
简介 Java 中比较常用的日志工具类,有: Log4j. SLF4j. Commons-logging(简称jcl). Logback. Log4j2(Log4j 升级版). Jdk Logging ...
- Spring Boot的日志配置
一.配置logback日志 Spring Boot默认使用logback打印日志 需要增加依赖 <groupId>org.springframework.boot</groupId& ...
- [日志] spring boot + logback 日志输出配置
一.输出日志到控制台 springboot有很多starter(参考starter)方便快速构建项目依赖组件,logback是springboot默认的日志组件,启动即可看到打印在控制台输出的info ...
- 携程Apollo(阿波罗)配置中心Spring Boot迁移日志组件,使用配置中心进行管理的思路
说明: 1.Spring Boot项目默认使用logback进行日志管理 2.logback在启动时默认会自动检查是否有logback.xml文件,如果有时会有限加载这个文件. 3.那么如果是用配置中 ...
随机推荐
- Go Exec 僵尸与孤儿进程
原文地址:Go Exec 僵尸与孤儿进程 最近,使用 golang 去管理本地应用的生命周期,期间有几个有趣的点,今天就一起看下. 场景一 我们来看看下面两个脚本会产生什么问题: 创建两个 shell ...
- Python 中 base64 编码与解码
base64 是经常使用的一种加密方式,在 Python 中有专门的库支持. 本文主要介绍在 Python2 和 Python3 中的使用区别: 在 Python2 环境: Python 2.7.16 ...
- Python变量与常见数据类型
Python变量 变量与常量:有时被通称为变量 变量:通常指代能够产生变化的量,多用以描述事物的变化状态 常量:通常指代稳定不产生变化的量,多用于描述事物的固定状态 # 代码层面的使用 myname ...
- 《Symfony 5全面开发》教程02、安装运行环境并初始化Symfony项目
Symfony是PHP框架,在学习Symfony之前,我们需要安装PHP运行环境.如果你是MacOS系统,可以使用Homebrew来安装PHP运行环境. Homebrew官网 https://brew ...
- 哈工大 计算机网络 实验二 可靠数据传输协议(停等协议与GBN协议)
计算机网络实验代码与文件可见github:计算机网络实验整理 实验名称 可靠数据传输协议(停等协议与GBN协议) 实验目的: 本次实验的主要目的. 理解可靠数据传输的基本原理:掌握停等协议的工作原理: ...
- 在win10操作系统中pycharm启动时无法打开的解决方法
''' 当打开pycharm时报错 Error launching Pycharm Failed to load JVM DLL C:\Program Files\Jetbrains\Pycharm ...
- MySQL第五讲
内容回顾 单表操作 """ 1.配置文件先统一设置成utf8 \s 2.无论你怎么改都没有生效 你的机器上不止一个mysql文件 C有一个 D有一个 3.百度搜索 sho ...
- LeetCode-047-全排列 II
全排列 II 题目描述:给定一个可包含重复数字的序列 nums ,按任意顺序 返回所有不重复的全排列. 示例说明请见LeetCode官网. 来源:力扣(LeetCode) 链接:https://lee ...
- C语言之判断质数算法
今天学校OJ的一题判断是质数和合数. 首先我们要弄明白质数和合数的概念:质数就是除了本身和1以外没有其他因数的数,合数就是除了本身和1以外还有其他因数的数.注意:1既不是质数也不是合数. 明白了概念, ...
- MySQL 8.0.13(Windows压缩版本)下载安装教程
MySQL下载安装教程 1.首先在百度上搜索mysql 2.点击链接进去,找到对应的路径 3.进去之后,可以看到版本是8.0.13,以及最下面有个Download按钮,点击下载 4.之后会跳转到开始下 ...