SpringBoot中的日志使用:
SpringBoot中的日志使用(一)
一:日志简介:
- 常用的日志接口 commons-logging/slf4j
- 日志框架:log4j/logback/log4j2
- 日志接口屏蔽了日志框架的底层实现,使用时只需引入相关的jar包,当更换日志的实现框架时,只需要修改pom文件或者日志配置文件,无需对代码层进行修改;
二:springboot使用logback的配置文件
- application.properties配置:
logging.path=/User/jackie/workspace/rome/ 日志的保存路径
logging.file=springbootLog.log 保存文件,注意file和path同时存在时,file生效,保存在根目录下,可以在file中设置路径如/logs/log/test.log
logging.level.root =warn 日志的保存级别,级别高于warn的被保存
logging.level.com.wht.logging.logger01=warn 可以设置某个具体包或者类的日志的保存级别;
logging.pattern.file=%d{yyyy/MM/dd-HH:mm:ss} [%thread] %-5level %logger :: %msg%n 日志的保存格式- logging.prattern.file解析:
%d{HH:mm:ss.SSS}——日志输出时间
%thread——输出日志的进程名字,这在Web应用以及异步任务处理中很有用
%-5level——日志级别,并且使用5个字符靠左对齐
%logger- ——日志输出者的名字
%msg——日志消息
%n——平台的换行符
三:logback的自定义配置
当我们想使用更高级的日志操作,比如我们希望将不同包下的日志记录到不同的位置,或者只想查看日志中包含否和特定正则的记录,此时需要logback‘的高级配置;
SpringBoot中默认使用logback作为日志实现。一般我们构建的springboot项目中包含spring-boot-starter-web,里面已经包含了logback的三个以来jar:
- logback-core:基础模块;
- logback-classic:log4j的改良;
- logback-access:提供通过http访问日志的功能
- springboot查找logback配置文件的顺序:首先查找logback.groovy,然后logback-test.xml,然后logback.xml文件,都没有使用默认设置;
logback.xml配置:
配置实例:appender负责具体日志输出。logger负责对相关包或者类进行控制;
<?xml version="1.0" encoding="UTF-8"?>
<configuration scan="true" scanPeriod="60 seconds" debug="true"> <!-- 控制台打印日志的相关配置,配置文件修改60s刷新,默认1min,debug=true显示logback内部日志信息 -->
<property name="location" value="./../logs/" /> <!--location表示了value值,在这作为日志的保存位置使用-->
<!--像控制台输出的日志格式,输出级别为warn以上的日志被打印-->
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>%d{yyyy-MM-dd-HH:mm:ss} [%class:%line] - %m%n</pattern>
</encoder>
<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
<level>warn</level>
</filter>
</appender>
<!--将日志保存到本地,filter设置级别,encoder设置格式,rollingPlicy设置日志滚动方式为基于时间滚动,保存格式为按天保存,最长时间为30天-->
<appender name="file1" class="ch.qos.logback.core.rolling.RollingFileAppender">
<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
<level>INFO</level>
</filter>
<encoder>
<pattern>%d{yyyy-MM-dd-HH:mm:ss} [%class:%line] - %m%n</pattern>
</encoder>
<!--<append>false</append>-->
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${location}%d{yy-MM-dd}.log</fileNamePattern>
<maxHistory>30</maxHistory>
</rollingPolicy>
</appender>
<!--仍然擦用该输出方式,file设置日志保存地址和日志名字,filter采用正则匹配的方式,
rollingPolicy策略为固定窗口策略:将日志压缩为如tets.1.log.zip格式放在location位置,其中%i必须带,范围为1-2;
triggeringPolocy定义了rollingPolicy的触发机制:采用基于文件大小的方式,当日志大于2k时进行压缩;-->
<appender name="file2" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${location}service.log</file>
<filter class="ch.qos.logback.core.filter.EvaluatorFilter">
<evaluator >
<matcher>
<Name>wht</Name>
<regex>^[ie]</regex>
</matcher>
<expression>wht.matches(formattedMessage)</expression>
</evaluator>
<OnMatch>ACCEPT</OnMatch>
<OnMismatch>DENY</OnMismatch>
</filter>
<rollingPolicy class="ch.qos.logback.core.rolling.FixedWindowRollingPolicy">
<fileNamePattern>${location}tests.%i.log.zip</fileNamePattern>
<minIndex>1</minIndex>
<maxIndex>2</maxIndex>
</rollingPolicy>
<triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">
<maxFileSize>2kB</maxFileSize>
</triggeringPolicy>
<encoder>
<pattern>%d{yyyy-MM-dd-HH:mm:ss} [%class:%line] - %m%n</pattern>
</encoder>
</appender>
<logger定义哪个包使用哪种appender进行日志输出,注意additivity默认不向上层传递,否则日志可能会被打印两遍>
<!--<logger name="com.wht.logger02.controller" level="DEBUG" additivity="false">;不向上层传递
<!--<appender-ref ref="file1"></appender-ref>-->
<!--</logger>-->
<logger name="com.wht.logger02.service" level="INFO" additivity="false">
<appender-ref ref="file2"></appender-ref>
</logger> <root level="INFO">
<appender-ref ref="STDOUT"></appender-ref>
</root> </configuration>
简单看下file2的日志输出: logging日志下是工程目录,service.log是正在生成的日志,test是已经打包的日志

SpringBoot中的日志使用:的更多相关文章
- SpringBoot中Logback日志的配置
说明 在SpringBoot中自带的日志工具是Logback,我们可以在Springboot的配置文件中直接对Logback进行一些简单的配置,如: logging.level.com.nowcode ...
- SpringBoot(三) SpringBoot中的日志配置
SLF4J Spring Boot在所有内部日志中使用Commons Logging,但是默认配置也提供了对常用日志的支持,如:Java Util Logging,Log4J, Log4J2和Logb ...
- springboot中的日志配置
日志方式:每天日志存放在一个文件中,info和warn日志存放一个文件,error存放一个文件 创建文件 logback-spring.xml <?xml version="1.0&q ...
- SpringBoot中的日志
默认情况下,Spring Boot会用SLF4J + Logback来记录日志,并用INFO级别输出到控制台. SLF4J,即简单日志门面(Simple Logging Facade for Java ...
- logback在springBoot项目中的使用 springboot中使用日志进行持久化保存日志信息
文章目录 1.xml文件的编写 2.实现的效果 2.1 日志保存到磁盘 2.2 控制台输出的效果 放置的位置 1.xml文件的编写 logback-spring.xml <?xml versio ...
- springboot logback + log4j2日志管理
springboot的web项目中自带了日志组件: 我们看一下,springboot中找到日志组件. <dependency> <groupId>org.springframe ...
- SpringBoot起飞系列-日志使用(四)
一.SpringBoot中的日志组件 日志是一个系统中不可缺少的组件.在项目中,我们常用的日志组件有JUL.JCL.Jboss-logging.logback.log4j.log4j2.slf4j.. ...
- 【SpringBoot】整合日志框架
一.日志框架概述 1.1 日志框架的产生 1.2 市面上的日志框架 二.SLF4j 使用与整合 2.1 如何在系统中使用SLF4j 2.2 如何整合日志框架 2.3 SpringBoot中的日志关系 ...
- Springboot中使用AOP统一处理Web请求日志
title: Springboot中使用AOP统一处理Web请求日志 date: 2017-04-26 16:30:48 tags: ['Spring Boot','AOP'] categories: ...
随机推荐
- .Net Core Aop之IActionFilter
一.简介 在.net core 中Filter分为以下六大类: 1.AuthorizeAttribute(权限验证) 2.IResourceFilter(资源缓存) 3.IActionFilter(执 ...
- tomcat 上传文件权限不足
参考:https://www.cnblogs.com/houchaoying/p/8652040.html tomcat-bin-catalina.sh UMASK="0027" ...
- 018 磁盘 IO 性能监控/压测工具(sar、iotop、fio、iostat)
1 sar 命令查看当前磁盘 IO 读写 sar(System Activity Reporter 系统活动情况报告)是 Linux 上最为全面的系统性能分析工具之一,可以从多方面对系统的活动进行报告 ...
- IDEA tomcat启动报错----Artifact is being deployed, please wait...解决
今天学习遇到了这个错误,记录下自己遇到的错误和解决方法! 这个报错的意思是: Artifact 正在部署中,请稍候- 实际上有可能就是jar包没有导进去.检查项目打包情况:file-->Proj ...
- python数据结构:数组和列表
线性结构有两种:数组和列表 array和list 其中list各项操作的时间复杂度如下 因为insert是在头部插入 所以列表所有元素后移,时间复杂度为O(n) remove移除列表中某个值的第一个匹 ...
- KTL 一个支持C++14编辑公式的K线技术工具平台 - 第四版,稳定支持Qt5编程,zqt5语法升级,MA函数提升性能1000%,更多公式算法的内置优化实现。
K,K线,Candle蜡烛图. T,技术分析,工具平台 L,公式Language语言使用c++14,Lite小巧简易. 项目仓库:https://github.com/bbqz007/KTL 国内仓库 ...
- 《Symfony 5全面开发》教程05、http请求的query参数
首先我们删除上节课所下的断点,在Phpstorm底部我们打开debug选项卡.点击这个按钮展开所有的PHP断点,选中之后点击这个删除,然后我们关闭xdebug监听. 回到浏览器刷新页面,当我们的浏览器 ...
- oj教程--贪心
贪心算法(又称贪婪算法)是指,在对问题求解时,总是做出在当前看来是最好的选择.也就是说,不从整体最优上加以考虑,他所做出的是在某种意义上的局部最优解. 贪心算法不是对所有问题都能得到整体最优解,关键是 ...
- idea教程--使用maven创建web项目
1.单击create new project 2.运行maven项目 在pom.xml文件中添加tomcat插件然后如下图运行;
- MyEclipse 启动tomcat本地服务,debug模式,代码一直不同步
今天写代码遇到一个问题,上午还能正常运行的代码,在eclipse中显示正常,但在游览器中就出现了差异,在网上找了很多方法: 1.add and remove项目,清理tomcat部署目录下的项目,清理 ...