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. 一个命令让redis服务端所有信息无所遁形~(收藏吃灰系列)

    1.info命令作用 在redis客户端执行INFO 命令以便于计算机解析和人工阅读的简单格式返回有关redis服务端的所有信息和统计数据. 可选参数可用于选择特定的信息部分: Server 服务器基 ...

  2. HashMap常用方法(简版)

    HashMap继承自Map,是一个散列表,它的存储形式是键-值对,键值对的类型可以不一样,这是它相较数组方便的一点. 1.put()方法 哈希表.put(key,value): 该方法用于将键值对加入 ...

  3. Oracle之非关系数据库

    什么是非关系型数据库? 非关系型数据库它的全称是Not Only SQL(简称 NoSQL数据库)是用于存储和检索数据的非关系数据库系统.在当今世界,我们不应该只以没有预定义固定模式的表格式存储所有数 ...

  4. SVG小图片格式显示(字符图标,可设置title属性)

    1.HTML + Font 方式: 修改图标颜色只需修改字体颜色,修改图片大小只需修改字体大小. 关于字体图片,我们可以自己制作,也可以从网上下载 阿里巴巴矢量图库. 在线图标字体库.Icomoon. ...

  5. idea常用快捷键及配置

    目录 常用快捷键 常用配置 配置修改项 版本2019.1.3,配置.破解插件见网盘 2020.3.4 链接:https://pan.baidu.com/s/1WHsS8-yvHGf1iRopLbKIu ...

  6. Maven打包异常:Failed to execute goal org.apache.maven.plugins:maven-war-plugin:2.2:war

    出现下面异常,因为默认web.xml在  src/main/webapp  下所以才出现找不到的异常. 我的项目结构为 解决办法①:  在pom.xml里面制定 web位置即可 //先确保打包方式为w ...

  7. 4.Profile(多环境配置)

    在实际的项目开发中,一个项目通常会存在多个环境,例如,开发环境.测试环境和生产环境等.不同环境的配置也不尽相同,例如开发环境使用的是开发数据库,测试环境使用的是测试数据库,而生产环境使用的是线上的正式 ...

  8. MongoDB创建普通账户与admin账户的配置方法

    MongoDB数据库设置账户及权限的方法 1.如果MongoDB服务正在运行的情况下,需先停止该服务 在cmd(命令提示符)下输入net stop MongoDB,按下enter(回车键) 运行结果: ...

  9. c# 去除TextBox的获取焦点事件

    /// <summary> /// 去除TextBox的获取焦点事件 /// </summary> /// <param name="sender"& ...

  10. Go标准的目录结构(自总结)

    微服务版 ├── LICENSE.md ├── Makefile //在任何一个项目中都会存在一些需要运行的脚本,这些脚本文件应该被放到 /scripts 目录中并由 Makefile 触发 ├── ...