springboot内部采用commons logging作为日志纪录,但也保留了第三方的日志框架接入的实现,例如Java Util Logging,Log4J2还有Logback。如果你要实现一种日志需要预先进行设置。spring boot默认使用logback做为日志框架

一、默认日志写法:

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

private final Log logger = LogFactory.getLog(getClass());

logger.info("打印INFO 日志信息");

输出的日志格式:

2017-09-13 11:29:40.341  INFO 4768 --- [nio-9090-exec-1] com.song.boot.controller.HomeController  : 打印INFO 日志信息

打印时间:为了便于排序,时间精确到毫秒级

日志级别:ERRORWARNINFODEBUG or TRACE (默认打印ERRORWARNINFO三级别日志消息)

进程ID

---分隔符:分隔符区分实际日志消息的开始

括号: 线程名称,使用括号方便截取

日志名称

日志具体消息

二、日志输出

springboot日志默认输出到console,不会输出外部文件。如果想要在控制台输出之外编写日志文件,则需要设置一个日志相关配置logging.file或logging.path在application.properties中

logging.file=D://my.log  (指定文件)

logging.path=E://my.log  (指定目录)

file比path级别高,如果配置file属性会过滤path。  path是生成一个my.log的文件,日志文件名spring.log

三、日志级别ERRORWARNINFODEBUG or TRACE

logging.level.root=WARN
logging.level.org.springframework.web=DEBUG
logging.level.org.hibernate=ERROR

四、定制化外面日志框架

通过classpath中类库可以激活相应的日志系统,或者在spring的环境属性logging.config进一步定制。

日志系统  定制文件

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

Log4j2  log4j2-spring.xml or log4j2.xml

JDK (Java Util Logging)  logging.properties  (会报出已知的加载类的问题,建议不要使用)

举例logback来详细说明配置:

logback的日志文件命名是logback-spring.xml,而不是logback.xml,原因是,命名为logback-spring.xml的日志配置文件,spring boot可以为它添加一些spring boot特有的配置项。

logback-spring.xml模板

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>%-16(%d{MM-dd HH:mm:ss}) %-5thread %logger{3} -%msg%n</pattern>
            <charset>utf8</charset>
        </encoder>
    </appender>
    <root level="INFO">
        <appender-ref ref="CONSOLE" />
    </root>
    
    <appender name="bootAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>E:/logs/boot.log</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <FileNamePattern>E:/logs/boot.log.%d{yyyy-MM-dd}</FileNamePattern>
        </rollingPolicy>
        <encoder>
            <pattern>%-16(%d{MM-dd HH:mm:ss}) %-5thread %logger{3} -%msg%n</pattern>
        </encoder>
    </appender>
    <logger name="bootAppender" additivity="false" level="INFO">
        <appender-ref ref="bootAppender" />
    </logger>
</configuration>

使用:

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
    private Logger log_console = LoggerFactory.getLogger(getClass()); //打印console输出
    private Logger log_boot = LoggerFactory.getLogger("bootAppender");//输出到外部文件

file:输出外面文件路径

rollingPolicy.FileNamePattern:文件分隔规则

encoder.pattern:输出格式

encoder.charset:输出内容字符码

logger.additivity:是否往上输出

logger.level:输出日志的级别

如果使用定制化外部日志框架, 并不需要去application.properties进行日志设置。若需要修改框架内部日志输出等级,在logback-spring.xml加入<logger name="org.springframework.web" level="DEBUG"/>

springboot 入门五-日志一的更多相关文章

  1. SpringBoot入门 (三) 日志配置

    上一篇博文记录了再springboot项目中读取属性文件中配置的属性,本文学习在springboot项目中记录日志. 日志记录在项目中是很常见的一个功能了,对排查问题有很大帮助,也可以做分类分析及统计 ...

  2. SpringBoot入门 (五) 数据库访问之spring data jpa

    本文记录学习使用spring data jpa访问数据库 一 什么是Spring Data JPA JPA(Java Persistence API)是Sun官方提出的Java持久化规范.它为Java ...

  3. SpringBoot入门基础

    目录 SpringBoot入门 (一) HelloWorld. 2 一 什么是springboot 1 二 入门实例... 1 SpringBoot入门 (二) 属性文件读取... 16 一 自定义属 ...

  4. SpringBoot入门一:基础知识(环境搭建、注解说明、创建对象方法、注入方式、集成jsp/Thymeleaf、logback日志、全局热部署、文件上传/下载、拦截器、自动配置原理等)

    SpringBoot设计目的是用来简化Spring应用的初始搭建以及开发过程.该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置.通过这种方式,SpringBoot致力于在蓬勃发 ...

  5. SpringBoot入门(五)——自定义配置

    本文来自网易云社区 大部分比萨店也提供某种形式的自动配置.你可以点荤比萨.素比萨.香辣意大利比萨,或者是自动配置比萨中的极品--至尊比萨.在下单时,你并没有指定具体的辅料,你所点的比萨种类决定了所用的 ...

  6. SpringBoot入门系列(十二)统一日志收集

    前面介绍了Spring Boot 异常处理,不清楚的朋友可以看看之前的文章:https://www.cnblogs.com/zhangweizhong/category/1657780.html. 今 ...

  7. SpringBoot入门及深入

    一:SpringBoot简介 当前互联网后端开发中,JavaEE占据了主导地位.对JavaEE开发,首选框架是Spring框架.在传统的Spring开发中,需要使用大量的与业务无关的XML配置才能使S ...

  8. SpringBoot入门教程(二)CentOS部署SpringBoot项目从0到1

    在之前的博文<详解intellij idea搭建SpringBoot>介绍了idea搭建SpringBoot的详细过程, 并在<CentOS安装Tomcat>中介绍了Tomca ...

  9. SpringBoot入门(三)——入口类解析

    本文来自网易云社区 上一篇介绍了起步依赖,这篇我们先来看下SpringBoot项目是如何启动的. 入口类 再次观察工程的Maven配置文件,可以看到工程的默认打包方式是jar格式的. <pack ...

随机推荐

  1. Tomcat多域名访问

    对于域名解析相信很多小伙伴都了解过,就是我们在万网购买一个域名,比如hpugs.com,然后呢?我们希望域名与我们的服务器绑定,然后通过域名直接访问我们的项目,这就是本篇要和大家一起探讨的问题.下面开 ...

  2. 【Win 10 应用开发】UI Composition 札记(八):用 XamlLight 制作灯光效果

    前面老周已介绍过灯光的使用,如果你忘了,请用九牛二虎之力猛点击这里去复习一下.本篇老周再介绍另一种添加灯光的方法,这种方法是专为 XAML 元素而设计的,可以很方便地为可视化元素添加灯光效果. 不知道 ...

  3. ASP.NET没有魔法——ASP.NET Identity 的“多重”身份验证

    ASP.NET Identity除了提供基于Cookie的身份验证外,还提供了一些高级功能,如多次输入错误账户信息后会锁定用户禁止登录.集成第三方验证.账户的二次验证等,并且ASP.NET MVC的默 ...

  4. MySql绿色版应用

    一.配置MySQL数据库 1.解压绿色版mysql,并改名为mysql5.7,如下图 对比一下下图5.6以前的版本,少data目录(存放数据)和my-default.ini文件(配置信息) 二.安装服 ...

  5. 企业级监控zabbix基础

    一个标准的监控系统所具备的基本功能: 1.数据的采集 2.为了展示其长期走势,将数据存储下来 3.万一某次采样的结果不在被认为是合理的范围内,然后就会做出告警操作,尽早的让相关人员得知到此消息 4.展 ...

  6. 【epub.js|翻译|原创】开源中间件epub.js的使用及其中文文档

    epub是最流行的电子书规范之一,网络上对于Java Web有不少合适的方法来解析和呈现,但是关于epub.js的介绍比较少(尽管github上已经2K星了),更多的是概念性的内容,如: epub.j ...

  7. JS 函数节流和去抖

    1.什么是节流和去抖? 节流.就是拧紧水龙头让水少流一点,但是不是不让水流了.想象一下在现实生活中有时候我们需要接一桶水,接水的同时不想一直站在那等着,可能要离开一会去干一点别的事请,让水差不多流满一 ...

  8. c#统计代码行数

    小编,已经快学了两年编程了.昨天突发奇想,想统计下这些年到底写过多少行代码,于是做了一个这个小程序来统计代码行数.老规矩,先上图. 比较惭愧,写了两年只有2万多行.那我们还是进入下一项吧. 界面搭建我 ...

  9. mysql故障解决笔记

    错误提示如图 一开始我查询了 [root@web01 mysql]# ls -al /lib/libc* -rwxr-xr-x 1 root root 1909464 Mar 22 01:49 /li ...

  10. 深入理解ES6之—增强的数组功能

    创建数组 Array.of()方法 ES6为数组新增创建方法的目的之一,是帮助开发者在使用Array构造器时避开js语言的一个怪异点.Array.of()方法总会创建一个包含所有传入参数的数组,而不管 ...