这篇博客是springboot日志配置探索的第一篇,主要讲默认配置下springboot的logback日志框架的配置(即直接使用是怎样的)

首先,是一个SpringBoot的有关日志的说明文档:https://docs.spring.io/spring-boot/docs/current/reference/html/boot-features-logging.html

然后我们按照文档的说明顺序来探索这个springboot的日志框架的配置吧

这里先简单介绍一下这个logback框架:(引自博客:https://blog.csdn.net/appleyk/article/details/78717388)

1

首先,一开始是做个总的介绍:

这里还说到,如果你是用staters的方法来用springboot,那么logback是默认拿来用来记录日志的,其实跑的时候那些info就是这个logback的作用了。

但我这里主要研究这个logback框架在springboot里的配置。

2

然后文档的下个部分就在说默认spring的集成的日志输出的格式:

 3

然后下一个部分,是讲默认在控制窗的输出:

默认的话,控制台会记录并输出ERROR,WARN,INFO等级的信息。下面先给个日志信息等级的排序:

TRACE < DEBUG < INFO < WARN < ERROR < FATAL。(最后那个FATAL在logback里面是没有的,在logback里面就是ERROR)

控制台输出这三个的信息,说明spring默认设置的日志等级是INFO,这个后面还会说

然后注意,这里讲到个debug模式,可以通过终端启动的时候输入java -jar myapp.jar --debug或者是直接在配置文件中设置debug=true来进入这个debug模式,这里要提到的是,这个debug模式并不是说,你那些debug等级以上的日志信息会输出,只是会输出很多像内置容器像tomcat,Hibernate, and Spring Boot等一堆有关的debug信息。   除了这个debug模式,还有个trace模式,文档中都有说:

我自己试了一下,debug模式就输出好多之前没看过的东西,还有什么springboot自动配置的报告……  然后trace模式就更恐怖了,打印的东西多到,机子直接跑不动STS……

 4

额然后下一个部分是讲输出的颜色,这个好像要看你的终端,然后也有的配置点东西,这里就不细讲了:

然后接着是讲文件输出的,我们在讲完文件输出的下一章LOG LEVEL再介绍这个文件输出的。

 5

接着的一节是讲Log level,也就是信息等级的:

等级是什么意思呢,比如说你设了root的输出等级是WARN,那么意思就是WARN以下的日志是不会输出的。     我们的配置方式就直接logging.level.*=level,然后上面给了三个内置的隐藏配置,也就是你一启动这个springboot,控制台输出的那些信息的隐藏配置就这三个,它们的意思是:

logging.level.root=WARN   #root日志以WARN级别输出
logging.level.org.springframework.web=DEBUG   #springframework.web日志以DEBUG级别输出
logging.level.org.hibernate=ERROR   #hibernate日志以ERROR级别输出

然后你可以定义自己的包的输出等级,这里先看在没有设置特定包的输出等级之前的输出效果,在controller里有个日志输出的测试函数:

package com.stuPayment.uiController;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping; @Controller
public class TestController { private final Logger logger = LoggerFactory.getLogger(getClass()); @RequestMapping("/test")
public String testPage() {
logger.trace("#######################hello this is trace");
logger.debug("#######################hello this is debug");
logger.info("#######################hello this is info");
logger.warn("#######################hello this is warn");
logger.error("#######################hello this is error");
return "test";
}
}

默认设置的输出效果,就只输出了info,warn,error等级的信息,说明默认设置是日志等级是info:

然后我们在application.properties中加入这一行设置:

logging.level.com.stuPayment.uiController=TRACE

然后再来看效果:

 6

然后就来看刚刚说的文件输出这一节:

做了几个实验,logging.file就不用说了,就只要注意如果直接省略“/”打路径与文件名那么路径是从项目文件里开始的,如果是用logging.path,如果像例子一样/var/log,那么会在D盘(我电脑是D盘)里面有个var/log/spring.log路径与文件,如果不加“/”,那么一样在项目文件下有这个路径和文件。

这里还提到关于日志最大文件的问题,默认是10M,到了10M会重新更新文件:

后面两个大概就是说日志的配置和初始化是在应用生命周期之前的,spring的配置和springboot是控制不了这个log的设置的。下面还会提到这个问题

 7

后面讲的是自定义日志配置还有日志文件的扩展了,这篇文章就先不讲,这里最后再提下如何改变输出格式pattern的配置。

这里还要说一下一个问题:

这里应该是说,日志框架的设置的初始化是在spring初始化之前的,所以按道理是无法通过spring的设置来改变日志的配置的,只能通过日志框架的System properties来配置,那么为什么我们前面能在application properties来配置这个日志框架呢?原因是spring的一些设置已经映射到日志框架中的配置去了:

好的然后继续来讲这个输出格式的问题,

这里提到是说如果你想在这个日志输出内容添加MDC(大概是多线程下可以记录用户信息的一个东西吧好像),可以通过设置这个logging.pattern.level来设置喔,那么不仅仅是这样,你想改变console的输出格式或者是文件中的日志输出格式或者是想改输出的日志的时间格式,输出的信息中等级描述的格式,都可以用这几个设置来配置:

具体的格式设置就不细讲了,这里找了个网上的例子:

Springboot日志配置探索(主要看logback)(一)的更多相关文章

  1. Springboot日志配置探索(主要看logback)(二)

    这篇博客主要是讲在Springboot中扩展的日志框架的配置,也是主要讲logback 8 继续看文档,这里讲到: springboot里面还有几个日志系统框架可以选择使用,你可以通过在classpa ...

  2. SpringBoot Logback配置,SpringBoot日志配置

    SpringBoot Logback配置,SpringBoot日志配置  SpringBoot springProfile属性配置 ================================ © ...

  3. 功能:SpringBoot日志配置详情

    SpringBoot日志配置详情 一.介绍 在所有的项目中,日志是必不可少的,为了高效清晰的查找日志,可以配置日志输出的等级和格式. 在配置后,可以自定义输出日志到指定目录,可以按照天数来分割日志,可 ...

  4. (转)Springboot日志配置(超详细,推荐)

    Spring Boot-日志配置(超详细) 更新日志: 20170810 更新通过 application.yml传递参数到 logback 中. Spring Boot-日志配置超详细 默认日志 L ...

  5. SpringBoot日志配置(详解) 涉及控制台输出日志、生成日志文件、日志级别修改、hibernate日志不输出

    写在前面 本篇主要讲述日志配置,看完本篇可以解决下述问题, 控制台输出日志.生成日志文件.日志级别修改.hibernate日志不输出 Git Demo Path:https://github.com/ ...

  6. springboot 日志配置

    maven依赖中添加了 spring-boot-starter-logging : <dependency> <groupId>org.springframework.boot ...

  7. springboot日志配置

    默认情况下,spring boot使用的是LogBack日志系统.在spring-boot-starter-web和spring-boot-starter中都已经默认依赖了logging的工具包. 如 ...

  8. 微服务-springboot日志配置

    springboot 默认会加载classpath:logback-spring.xml文件. springProfile 中的name名字对应application-xx.properties 中的 ...

  9. ELK springboot日志收集

    一.安装elasticsearch 可以查看前篇博客 elasticsearch安装.elasticsearch-head 安装 二.安装 配置 logstash 1.安装logstash 下载地址: ...

随机推荐

  1. 人生苦短之Python装饰器

    在Python中函数也是一个对象,我们可以获得函数对象,然后执行函数 def func(): print('I am very good') a = func a 如果我们要是想增强这个函数呢?比如给 ...

  2. #pragma once与#ifndef

    都是为了避免同一个头文件被包含多次.在编译器对这两种方式都支持的情况下,区别很小. 方式一: #pragma once ...//这里放声明语句 方式二: #ifndef 宏名 #def 宏名 ... ...

  3. 【转载】Myeclipse中实现js的提示

    近期需要大量使用JS来开发,但是MyEclipse2014自带的JS编辑器没有代码提示的功能,开发效率有点低,所以安装了一个Spket的插件,过程非常简单,SVN插件的安装比这个更简单. Spket插 ...

  4. 骨牌覆盖问题 KxM

    前面我们说了一些简单的骨牌覆盖问题,有了上面的经验,我们可以尝试解决K*M的 思路和上一篇文章所提到的3*N的 很类似: 依然是矩阵快速幂.我们需要把一个小的边固定下来作为的已知边,然后进行矩阵快速幂 ...

  5. java中的几种内部类

    Java中的几种内部类 内部类,听名字就可以知道是什么意思,就是类里面的类.有成员内部类,静态内部类,局部内部类和匿名内部类. 下面说一个每种内部类的的使用. 一.  成员内部类

  6. adb pull / push

    刚才搞了半天想pull,就是pull不成,如图: 看出哪里有问题了吗? 问题就是我不该在shell里面运行adb pull! 正确的做法: 在任意一处打开命令行比如图中的桌面, adb pull /s ...

  7. SPOJ:Another Longest Increasing Subsequence Problem(CDQ分治求三维偏序)

    Given a sequence of N pairs of integers, find the length of the longest increasing subsequence of it ...

  8. LeetCode 889. Construct Binary Tree from Preorder and Postorder Traversal

    原题链接在这里:https://leetcode.com/problems/construct-binary-tree-from-preorder-and-postorder-traversal/ 题 ...

  9. TFS独占签出代码

    最近发现微软给我们提供了免费的TFS,地址:http://tfs.visualstudio.com/, 就注册了一个,但是我发现没办法独占签出. 在公司里,TFS有服务端,所以很好设置,但是注册微软的 ...

  10. monkey基本命令及脚本编写

    Monkey 是Android自带的黑盒测试工具,一般通过随机触发界面事件,来确定应用是否会发生异常,多用于android应用的稳定性.压力测试  基本命令: adb shell monkey [op ...