【二十八】springboot整合logback实现日志管理

        本章节是记录logback在springboot项目中的简单使用,本文将会演示如何通过logback将日志记录到日志文件或输出到控制台等管理操作。将会从以下几个方面进行讲解。最后实现将特定级别的特定日志保存到日志文件。

一、依赖


            ch.qos.logback
            logback-classic
            1.2.10
        

        
            org.codehaus.janino
            janino
            3.0.6
        

以上版本只是测试时使用,实际版本根据项目来。 

二、标签介绍

1、configuration

logback配置文件的根标签

属性:

scan:当此属性设置为true时,配置文件如果发生改变,将会被重新加载,默认值为true。
scanPeriod:设置监测配置文件是否有修改的时间间隔,如果没有给出时间单位,默认单位是毫秒,当scan为true时,此属性生效。默认的时间间隔为1分钟。
debug:当此属性设置为true时,将打印出logback内部日志信息,实时查看logback运行状态。默认值为false
2、springProperty

我理解的是配置常量值的数据来源和默认值

属性:

scope:作用域
name:变量名称
source:数据来源
defaultValue:默认值
3、property

定义常量和给常量赋值

属性:

name:常量名称
value:常量值
4、appender

日志的具体格式或者保存地址等配置处理

属性:

name:appender的名字
class:类型,有ConsoleAppender、RollingFileAppender、AsyncAppender、FileAppender。ConsoleAppender:控制台日志。
RollingFileAppender:滚动文件日志,继承于FileAppender,使用更便捷。
AsyncAppender:异步日志,相较于其他的,他不负责处理日志,只是将日志缓冲到一个BlockingQueue里面去,并在内部创建一个工作线程从队列头部获取日志,之后将获取的日志循环记录到附加的其他 appender上去,从而达到不阻塞主线程的效果。因此AsynAppender仅仅充当事件转发器,必须引用另一个appender来做事。
FileAppender:文件日志,我们不做演示,就用RollingFileAppender演示,功能差不多。
5、logger

单独对某种日志做处理

6、root

统一的所有日志的处理(除了logger处理的)

三、实例演示

        加入现在我有这样一个需求:1、项目本身的日志我想记录下来保存文件并打印控制台;2、springfox.documentation这个包下面关于swagger的日志我觉得没有用处并不想存入文件只打印控制台就可以了;3、其他的第三方包该输出什么日志就都保存文件并打印控制台不做干涉;4、我还想做一个配置可以控制向日志文件输出的开关。

有了这个需求,我们就可以开始做了。

1、新建一个xml文件

【二十八】springboot整合logback实现日志管理_第1张图片

【二十八】springboot整合logback实现日志管理_第2张图片

留下如上内容。

2、增加configuration标签



3、由于需要控制是否需要向日志文件输入就需要新增一个变量来控制一下,通过springProperty标签实现

【二十八】springboot整合logback实现日志管理_第3张图片

        我们后面需要指定一个文件存日志,文件名就叫项目名,所以再增加一个项目名变量,同样通过springProperty标签实现。

【二十八】springboot整合logback实现日志管理_第4张图片

【二十八】springboot整合logback实现日志管理_第5张图片

4、通过property标签新增几个常量来统一一下文件配置的一些值

【二十八】springboot整合logback实现日志管理_第6张图片

5、通过appender标签实现日志的处理规则

【二十八】springboot整合logback实现日志管理_第7张图片

        新增三个类型的appender,class如上固定路径。设置编码格式和输出格式等。异步日志appender绑定到name为rolling的滚动日志即为实际是走name为rolling的appender逻辑,只是先到async缓冲一下。

6、新增logger便签,配置成项目本身的日志通过变量来控制是否输入到日志文件,而springfox.documentation这个包只输出到控制台

【二十八】springboot整合logback实现日志管理_第8张图片

7、再配置root标签

【二十八】springboot整合logback实现日志管理_第9张图片

        没有特别定义则默认为root,任何一个类只会和一个logger对应。

8、验证

【二十八】springboot整合logback实现日志管理_第10张图片

        随便增加一个项目本身的日志输出,启动项目。

【二十八】springboot整合logback实现日志管理_第11张图片

        可以看到多了一个日志文件。

【二十八】springboot整合logback实现日志管理_第12张图片

        可以看到特殊处理的包日志文件没有,而控制台存在。

【二十八】springboot整合logback实现日志管理_第13张图片

        而项目本身的日志确实是都存在。手动清空日志文件,并将配置改为关闭,重启项目。

【二十八】springboot整合logback实现日志管理_第14张图片

【二十八】springboot整合logback实现日志管理_第15张图片

        可以看到确实没有向日志文件输出了,控制台的日志也明显较少,只有项目本身的日志和springfox.documentation的日志了。

【二十八】springboot整合logback实现日志管理_第16张图片

        logback的笔记到此结束,欢迎交流。 

你可能感兴趣的:(spring,boot,logback,java)