springboot中使用logback
原文地址:https://blog.csdn.net/tianyaleixiaowu/article/details/73321610
Springboot默认集成的就是logback,logback相对来说是优秀于log4j的,log4j2也是参考了logback的设计。本篇就是来看看如何使用logback。
新建一个Springboot项目,勾选web就OK了,项目会自动集成logback。
控制台日志
写一个controller测试一下:
- import org.slf4j.Logger;
- import org.slf4j.LoggerFactory;
- import org.springframework.web.bind.annotation.GetMapping;
- import org.springframework.web.bind.annotation.RestController;
- /**
- * Created by admin on 17/6/16.
- */
- @RestController
- public class IndexController {
- private final Logger logger = LoggerFactory.getLogger(getClass());
- @GetMapping("/index")
- public Object index() {
- logger.debug("debug");
- logger.info("info");
- logger.warn("warn");
- logger.error("error");
- return "success";
- }
- }
需要注意:Logger是slf4j包中的logger,别引用错了。slf4j是一个工厂,可以和log4j、logback结合使用,熟悉工厂模式的自然理解。引用了logback那么Logger就会使用logback相关的方法来处理日志,引用了log4j也同理,这样能便于我们切换日志的实际处理类,这是工厂模式的优点。不要同时引用两个日志处理框架,这样工厂会懵逼的。
访问上面的controller,查看控制台打印:
2017-06-16 09:54:13.966 INFO 60356 --- [nio-8080-exec-1] c.e.demo.controller.IndexController : info
2017-06-16 09:54:13.967 WARN 60356 --- [nio-8080-exec-1] c.e.demo.controller.IndexController : warn
2017-06-16 09:54:13.967 ERROR 60356 --- [nio-8080-exec-1] c.e.demo.controller.IndexController : error
我们发现除了debug没出来,其他的都出来了。
这是因为Springboot的日志level来控制的,根据不同的level来显示。在哪里控制呢?正常来说,应该是由我们在resources下配置的spring-logback.xml来控制,但是我们什么都没写,那么他就走了Springboot默认的配置。
这里就是Springboot对logback配置的地方,base.xml里,可以看到root level=INFO,这个代表该项目默认是输出最低为info级别的日志。然后看到有两个append-ref,分别为console何file,这两个分别对应上面引用的两个include resource里的xml,每个名字对应一个处理类。
ConsoleAppender和FixedWindowRollingPolicy都是logback提供的两个Appender处理类,Appender类代表了对日志的处理方法,这个可以自定义。系统提供了很多个Appender,基本满足了大部分场景的需求,像Console就是输出到控制台的,System.out.print之类的,而File的就是输出到日志文件的。
刚才可以看到在控制台已经打印出了info及以上级别的日志了,那日志文件在哪里呢?
日志文件
file: ./logback.log
修改其他配置
file: ./logback.log
level:
com.example.demo: debug
使用自定义配置
修改日志级别
- <?xml version="1.0" encoding="UTF-8"?>
- <configuration>
- <include resource="org/springframework/boot/logging/logback/base.xml" />
- <root level="WARN">
- <appender-ref ref="CONSOLE" />
- <appender-ref ref="FILE" />
- </root>
- </configuration>
这里引用了base.xml并覆盖了root level为WARN,重启项目,并访问index
按包名区分日志级别
- <?xml version="1.0" encoding="UTF-8"?>
- <configuration>
- <include resource="org/springframework/boot/logging/logback/base.xml" />
- <root level="INFO">
- <appender-ref ref="CONSOLE" />
- <appender-ref ref="FILE" />
- </root>
- <logger name="org.springframework.web" level="INFO"/>
- <logger name="com.example.demo" level="WARN"/>
- </configuration>
在xml里配置不同的包的日志level。结果自行测试。
按部署环境区分日志级别
- <?xml version="1.0" encoding="UTF-8"?>
- <configuration>
- <include resource="org/springframework/boot/logging/logback/base.xml" />
- <root level="INFO">
- <appender-ref ref="CONSOLE" />
- <appender-ref ref="FILE" />
- </root>
- <!-- 测试环境+开发环境. 多个使用逗号隔开. -->
- <springProfile name="test,dev">
- <logger name="org.springframework.web" level="INFO">
- <appender-ref ref="FILE"/>
- </logger>
- <logger name="com.example" level="INFO" />
- </springProfile>
- <!-- 生产环境. -->
- <springProfile name="prod">
- <logger name="org.springframework.web" level="ERROR">
- <appender-ref ref="FILE"/>
- </logger>
- <logger name="com.example" level="ERROR" />
- </springProfile>
- </configuration>
写法如上,然后在yml里配置spring.profiles.active = dev结果自行测试。
按时间自动滚动的日志文件
- <appender name="MY_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
- <Prudent>true</Prudent>
- <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
- <fileNamePattern>logFile.%d{yyyy-MM-dd}.log</fileNamePattern>
- <maxHistory>30</maxHistory>
- <totalSizeCap>3GB</totalSizeCap>
- </rollingPolicy>
- <layout class="ch.qos.logback.classic.PatternLayout">
- <Pattern> %d{yyyy-MM-dd HH:mm:ss} -%msg%n</Pattern>
- </layout>
- <encoder>
- <pattern>%-4relative [%thread] %-5level %logger{35} - %msg%n</pattern>
- </encoder>
- </appender>
我们定义一个name为MY_FILE的appender,配置fileName策略为按年月日.log的文件名,然后就可以使用这个Appender了。
- <!-- 测试环境+开发环境. 多个使用逗号隔开. -->
- <springProfile name="test,dev">
- <logger name="org.springframework.web" level="INFO">
- <appender-ref ref="MY_FILE"/>
- </logger>
- </springProfile>
需要注意,Appender的定义要在上面,使用它的地方要在下面,不然会报错找不到Appender。
自定义Appender
如果以上都不能满足要求,需要自定义Appender,譬如我们希望把日志除了往文件、控制台外,再往mongoDB输出一份,那么就需要自定义一个mongoAppender。回头等我实验好了,就弄一个mongoAppender。
springboot中使用logback的更多相关文章
- 在SpringBoot中使用logback优化异常堆栈的输出
一.背景 在我们在编写程序的过程中,无法保证自己的代码不抛出异常.当我们抛出异常的时候,通常会将整个异常堆栈的信息使用日志记录下来.通常一整个异常堆栈的信息是比较多的,而且存在一些没用的信息.那么我们 ...
- 在SpringBoot中添加Logback日志处理
前言 SpringBoot项目中在官方文档中说明,默认已经依赖了一些日志框架.而其中推荐使用的就是Logback,所以这一次我将在我的模版中加入Logback日志的配置,说明一下,SpringBoot ...
- SpringBoot(三) - Slf4j+logback 日志,异步请求,定时任务
1.Slf4j+logback 日志 SpringBoot框架的默认日志实现:slf4j + logback: 默认日志级别:info,对应了实际生产环境日志级别: 1.1 日志级别 # 常见的日志框 ...
- 在SpringBoot项目中添加logback的MDC
在SpringBoot项目中添加logback的MDC 先看下MDC是什么 Mapped Diagnostic Context,用于打LOG时跟踪一个“会话“.一个”事务“.举例,有一个web ...
- springboot中动态修改logback日志级别
springboot中动态修改logback日志级别 在spring boot中使用logback日志时,项目运行中,想要修改日志级别. 代码如下: import org.slf4j.Logger; ...
- SpringBoot中Logback日志的配置
说明 在SpringBoot中自带的日志工具是Logback,我们可以在Springboot的配置文件中直接对Logback进行一些简单的配置,如: logging.level.com.nowcode ...
- Springboot的日志管理&Springboot整合Junit测试&Springboot中AOP的使用
==============Springboot的日志管理============= springboot无需引入日志的包,springboot默认已经依赖了slf4j.logback.log4j等日 ...
- SpringBoot整合Slf4j+logback日志框架
一.Slf4j简单介绍与优势 1.介绍 Slf4j的全称是Simple Loging Facade For Java(Java简单日志门面),它仅仅是一个为Java程序提供日志输出的统一接口,并不是一 ...
- SpringBoot 异步输出 Logback 日志
一.介绍 1.1 Logback Logback是由log4j创始人设计的另一个开源日志组件,它分为下面下个模块: logback-core:其它两个模块的基础模块 logback-classic:它 ...
随机推荐
- 一道非常棘手的 Java 面试题:i++ 是线程安全的吗
转载自 一道非常棘手的 Java 面试题:i++ 是线程安全的吗 i++ 是线程安全的吗? 相信很多中高级的 Java 面试者都遇到过这个问题,很多对这个不是很清楚的肯定是一脸蒙逼.内心肯定还在质疑 ...
- JavaSE基础---多线程
进程:正在进行的程序.其实就是一个应用程序运行时的内存分配空间. 线程:进程中一个程序执行控制单元,一条执行路径.进程负责的事应用程序的空间的标识,线程负责的事应用程序的执行顺序. 进程和线程的关系: ...
- 【hdu 1850】Being a Good Boy in Spring Festival
Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submission(s) ...
- HDU - 1005 Number Sequence (矩阵快速幂)
A number sequence is defined as follows: f(1) = 1, f(2) = 1, f(n) = (A * f(n - 1) + B * f(n - 2)) mo ...
- Java 学习笔记(16)——Java数据库操作
数据库操作是程序设计中十分重要的一个部分,Java内置JDBC来操作数据库 JDBC使用 JDBC--Java Database connecting Java数据库连接:本质上JDBC定义了操作数据 ...
- Python13_安装、解释器
Linux下大部分系统默认自带python2.x的版本,最常见的是python2.6或python2.7版本,默认的python被系统很多程序所依赖, 比如centos下的yum就是python2写的 ...
- mac笔记本安装Android sdk
一.先下载android sdk for mac 给二个靠谱的网址: a). http://down.tech.sina.com.cn/page/45703.html b). http://mac ...
- CentOs7.X下配置FTP
https://blog.csdn.net/cc_want/article/details/85337241 CentOS7.x自带firewall防火墙,FTP使用需要开启20 21 22 3000 ...
- The sixth day of Crawler learning
爬取我爱竞赛网的大量数据 首先获取每一种比赛信息的分类链接 def get_type_url(url): web_data = requests.get(web_url) soup = B ...
- linux-free、lscpu、
1.free -h 以人类可读的形式显示 -m 以MB为单位显示 -w 将buffers和cache分开单独显示(针对centos7系统) centos6上: centos7上: -s 动态查看内存信 ...