SpringBoot整合logback的示例代码

网友投稿 317 2022-08-15


SpringBoot整合logback的示例代码

Logback简介

2、logback分为三个模块, logback-core, logback-classic 和logback-access,其中 logback-core是核心,其他两个模块依赖core,这个logback-classic是log4j的改善版本,并且原生实现了SLF4J门面(具体参考前文:java中SLF4J日志框架的实现原理)。模块logback-access可以集成于Servlet容器,比如Tomact和Jetty。

3、你可以基于logback-core自己创建其他的模块。

Logback相比log4j的优势

比log4j更快,重写了内核,在一些关键路径上性能提升10倍,内存占用也更少。经过大量的测试,和log4j测试不在一个量级。logback-classic是SLF4J的实现,切换其他日志框架非常方便,文档丰富并且不断更新,支持Groovy风格的配置文件配置文件自动重新加载,如果更新了配置文件,logback-classic可以自动重新加载。自动删除日期较老的日志文件,maxHistory属性,你可以控制已经产生日志文件的最大数量。如果设置maxHistory为12,那那些log文件超过12个月的都会被自动移除。自动压缩归档的日志文件,压缩文件是异步进行,不影响应用。配置文件可以处理不同的环境开发,测试,生产),这样一个配置文件就可以适应多个环境。SiftingAppender(一个非常多功能的Appender) 它可以用来分割日志文件根据任何一个给定的运行参数。如,SiftingAppender能够区别日志事件跟进用户的Session,然后每个用户会有一个日志文件。

下面看下SpringBoot整合logback的方法。

spring-boot-starter-web这个包几乎是使用SpringBoot时必备的,其内部已经依赖了logback的组件,也就是说SpringBoot已经帮你整合了logback。

只需要在resources目录加上logback.xml文件,写入内容如下:

其中路径、包名称、保留周期等 根据自己的需要进行修改即可

${log.pattern}

${log.path}/sys-info.log

${log.path}/sys-info.%d{yyyy-MM-dd}.log

60

INFO

ACCEPT

DENY

${log.path}/sys-error.log

${log.path}/sys-error.%d{yyyy-MM-dd}.log

${log.pattern}

ERROR

${log.path}/sys-user.log

${log.path}/sys-user.%d{yyyy-MM-dd}.log

60

在yml文件中加入如下配置:

logging:

level:

cn.vantee: debug

cn.vantee.mapper: trace

config: classpath:logback.xml

在需要打印日志的类上加入@Slf4j注解,即可使用log.info()、log.error()、log.debug()...打印日志。日志会自动记录在logback.xml中指定的文件内


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Java虚拟机内存结构及编码实战分享
下一篇:Android Rxjava3 使用场景详解
相关文章

 发表评论

暂时没有评论,来抢沙发吧~