【串线篇】spring boot日志使用

、默认配置

1.SpringBoot默认帮我们配置好了日志;

//记录器
Logger  logger  =  LoggerFactory.getLogger(getClass()); @Test
public void contextLoads() {
//System.out.println();
//日志的级别;
//由低到高,trace<debug<info<warn<error
//可以调整输出的日志级别;日志就只会在这个级别以以后的高级别生效
logger.trace("这是trace日志...");
logger.debug("这是debug日志...");
//SpringBoot默认给我们使用的是info级别的,没有指定级别的就用SpringBoot默认规定的级别;root级别
logger.info("这是info日志...");
logger.warn("这是warn日志...");
logger.error("这是error日志...");
}

日志输出格式:

%d表示日期时间,

%thread表示线程名,

%‐5level:级别从左显示5个字符宽度

%logger{50}  表示logger名字最长50个字符,否则按照句点分割。

%msg:日志消息,

%n是换行符

‐‐>

%d{yyyy‐MM‐dd  HH:mm:ss.SSS}  [%thread]  %‐5level  %logger{50}  ‐  %msg%n

2.SpringBoot修改日志的默认配置

logging.level.com.atguigu=trace

#logging.path=
# 不指定路径在当前项目下生成springboot.log日志
# 可以指定完整的路径;
#logging.file=G:/springboot.log

# 在当前磁盘的根路径下创建spring文件夹和里面的log文件夹;使用 spring.log 作为默认文件
logging.path=/spring/log

# 在控制台输出的日志的格式
logging.pattern.console=%d{yyyy‐MM‐dd}  [%thread]  %‐5level  %logger{50}  ‐  %msg%n # 指定文件中日志输出的格式
logging.pattern.file=%d{yyyy‐MM‐dd}  ===  [%thread]  ===  %‐5level  ===  %logger{50}  ====  %msg%n

logging.?le


logging.path


Example


Description


(none)


(none)


只在控制台输出


指定文件名


(none)


my.log


输出日志到my.log文件


(none)


指定目录


/var/log


输出到指定目录的 spring.log 文件中

二、指定配置

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


Logging System


Customization


Logback


logback-spring.xml,   logback-spring.groovy,   logback.xml  or

logback.groovy


Log4j2


log4j2-spring.xml  or   log4j2.xml

 
logging.properties【Logging System对应是JDK ( Java Util Logging)】

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

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

的高级Pro?le功能

    <springProfile  name="staging">
    <!‐‐ configuration to be enabled when the "staging" profile is active ‐‐>
    可以指定某段配置只在某个环境下生效
    </springProfile> 

如:

<appender  name="stdout"  class="ch.qos.logback.core.ConsoleAppender"> 2        <!‐‐
    日志输出格式:
    %d表示日期时间,
    %thread表示线程名,
    %‐5level:级别从左显示5个字符宽度
    %logger{50}  表示logger名字最长50个字符,否则按照句点分割。
    %msg:日志消息,
    %n是换行符
    ‐‐>
    <layout class="ch.qos.logback.classic.PatternLayout">
    <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>
    </layout>
    </appender>

如果使用logback.xml作为日志配置文件,还要使用pro?le功能,会有以下错误

no applicable action for [springProfile]

三、切换日志框架

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

slf4j+log4j的方式;

<dependency>
  <groupId>org.springframework.boot</groupId>
    <artifactId>spring‐boot‐starter‐web</artifactId>
    <exclusions>
       <exclusion>
       <artifactId>logback‐classic</artifactId>
       <groupId>ch.qos.logback</groupId>
       </exclusion>       <exclusion>
       <artifactId>log4j‐over‐slf4j</artifactId>
       <groupId>org.slf4j</groupId>
       </exclusion>

   </exclusions>
</dependency>
<dependency>
  <groupId>org.slf4j</groupId>
  <artifactId>slf4j‐log4j12</artifactId>
</dependency>

切换为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>

原文地址:https://www.cnblogs.com/yanl55555/p/12090240.html

时间: 2024-10-14 03:40:55

【串线篇】spring boot日志使用的相关文章

四、spring boot 日志管理

spring boot日志默认采用logback进行输出,你可以对logback进行定制化,方法如下: 在resources文件夹下建立logback.xml配置文件 <?xml version="1.0" encoding="UTF-8"?> <configuration> <!-- base.xml in the spring-boot jar, --> <include resource="org/sprin

Spring Boot 日志记录 SLF4J

Spring Boot 日志记录 SLF4J 2016年01月12日 09:25:28 阅读数:54086 在开发中打印内容,使用 System.out.println() 和 Log4j 应当是人人皆知的方法了. 其实在开发中我们不建议使用 System.out 因为大量的使用 System.out 会增加资源的消耗. 而Log4j 更为灵活在性能上也相比 System.out 要高,我们可以配置输出级别,可以指定多个日志文件分别记录不同的日志. 使用 System.out 是在当前线程执行的

从.Net到Java学习第四篇——spring boot+redis

从.Net到Java学习第一篇——开篇 从.Net到Java学习第二篇——IDEA and start spring boot 从.Net到Java学习第三篇——spring boot+mybatis+mysql 接上一篇,本篇使用到的框架redis.FastJSON. 环境准备 安装redis,下图是我本机的redis绿色版,你可以网上自行下载安装,如果不知道如何怎么操作,可以移步到我的另一篇文章:ASP.NET Redis 开发 以管理员身份打开CMD窗口: C:\Users\zouqj>e

Springboot 系列(四)Spring Boot 日志框架

注意:本 Spring Boot 系列文章基于 Spring Boot 版本 v2.1.1.RELEASE 进行学习分析,版本不同可能会有细微差别. 前言 Spring 框架选择使用了 JCL 作为默认日志输出.而 Spring Boot 默认选择了 SLF4J 结合 LogBack.那我们在项目中该使用哪种日志框架呢?在对于不同的第三方 jar 使用了不同的日志框架的时候,我们该怎么处理呢? 1. 日志框架介绍 日志对于应用程序的重要性不言而喻,不管是记录运行情况还是追踪线上问题,都离不开对日

让你的spring-boot应用日志随心所欲--spring boot日志深入分析

1.spring boot日志概述 spring boot使用Commons Logging作为内部的日志系统,并且给Java Util Logging,Log4J2以及Logback都提供了默认的配置.如果使用了spring boot的Starters,那么默认会使用Logback用于记录日志. 2.spring boot日志默认配置 我们启动一个空的spring-boot项目看一下控制台的日志 控制台的默认配置 logging.pattern.console=%clr(%d{${LOG_DA

Spring Boot 日志管理

Spring Boot 日志管理 网址 Spring Boot 日志管理 http://blog.didispace.com/springbootlog/ Spring Boot快速入门(四)--日志系统 https://leibnizhu.gitlab.io/2016/11/26/Spring-Boot%E5%BF%AB%E9%80%9F%E5%85%A5%E9%97%A8%EF%BC%88%E5%9B%9B%EF%BC%89%E2%80%94%E2%80%94%E6%97%A5%E5%BF%

Spring Boot日志管理

Spring Boot在所有内部日志中使用Commons Logging,但是默认配置也提供了对常用日志的支持,如:Java Util Logging,Log4J, Log4J2和Logback.每种Logger都可以通过配置使用控制台或者文件输出日志内容. 格式化日志 默认的日志输出如下: 1 2016-04-13 08:23:50.120 INFO 37397 --- [ main] org.hibernate.Version : HHH000412: Hibernate Core {4.3

spring boot日志配置

spring boot的application.properties提供了日志的配置,但我还是习惯于老的logback的使用方式.以下内容介绍如何在springboot中使用自定义的logback. 1.在src/main/resources目录下创建logback.xml文件,内容如下: <!-- Logback configuration. See http://logback.qos.ch/manual/index.html --> <configuration scan=&quo

Spring Boot 日志

日志框架是任何一套系统中不可获取的部分,我们需要通过日志来记录用户的有效操作. JUL: JDK 自带的Logging(实现太过简陋,对开发者不友好) JCL: Jakarta Commons Loggin(Apache)() Log4j:(作者是ceki,Log4j是作者选择放弃而推荐Logback) Log4j2:(Apache,过于先进,开源框架对其支持有限,最大的优势是高于Log4j的超高性能) Logback:(作者是ceki,真正意义上的Log4j2) SLF4j:(作者是ceki,