打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
logback系列之四:输出日志到不同文件
logback系列之一:输出日志到控制台
logback系列之二:输出日志到文件
logback系列之三:输出日志到文件(滚动)
logback系列之四:输出日志到不同文件


为了方便查看和归档:
不同包的日志可能要放到不同的文件中,如service层和dao层的日志;
不同日志级别:调试、信息、警告和错误等也要分文件输出。

一、根据包输出,通过logger的name属性指定不同的包

1. 创建不同包下的两个类:
Java代码  
  1. package com.john.service;  
  2.   
  3. @Service  
  4. public class ObligationService {  
  5.     static final Logger log = LoggerFactory.getLogger(ObligationService.class);  
  6.   
  7.     @Resource  
  8.     ObligationDao dao;  
  9.       
  10.     public void obligate() {  
  11.         log.debug("obligate start...");  
  12.         dao.queryObligations();  
  13.         log.error("An error occurred during the progress");  
  14.         log.debug("obligate end...");  
  15.     }  
  16. }  


Java代码  
  1. package com.john.dao;  
  2.   
  3. @Repository  
  4. public class ObligationDao {  
  5.     static final Logger log = LoggerFactory.getLogger(ObligationDao.class);  
  6.       
  7.     public void queryObligations() {  
  8.         log.debug("query obligations start...");  
  9.         log.error("An error occurred during the query");  
  10.         log.debug("query obligations end...");  
  11.     }  
  12. }  


2. 在logback(-test).xml中添加:
Xml代码  
  1. <appender name="serviceAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">  
  2.     <file>/logs/bribery.log</file>  
  3.     <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">  
  4.         <fileNamePattern>/logs/bribery-%d{yyyy-MM-dd}.log</fileNamePattern>  
  5.     </rollingPolicy>  
  6.     <encoder>  
  7.         <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{5} - %msg%n</pattern>  
  8.     </encoder>  
  9. </appender>  
  10.   
  11. <appender name="daoAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">  
  12.     <file>/logs/venality.log</file>  
  13.     <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">  
  14.         <fileNamePattern>/logs/venality-%d{yyyy-MM-dd}.log</fileNamePattern>  
  15.     </rollingPolicy>  
  16.     <encoder>  
  17.         <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{5} - %msg%n</pattern>  
  18.     </encoder>  
  19. </appender>  
  20.   
  21. <logger name="com.john.service" level="DEBUG" additivity="false">  
  22.     <appender-ref ref="serviceAppender" />  
  23. </logger>  
  24.   
  25. <logger name="com.john.dao" level="DEBUG" additivity="false">  
  26.     <appender-ref ref="daoAppender" />  
  27. </logger>  


在类路径下创建Spring的beans.xml文件:(beans节点省略)
Xml代码  
  1. <context:component-scan base-package="com.john" />  


3. 测试方法:
Java代码  
  1. @Test  
  2. public void dispatchByPackageTest() {  
  3.     AbstractApplicationContext ctx = new ClassPathXmlApplicationContext("beans.xml");  
  4.     ObligationService service = ctx.getBean(ObligationService.class);  
  5.     service.obligate();  
  6. }  

执行测试后,
bribery.log:
15:59:59.839 [main] DEBUG c.j.s.ObligationService - obligate start...
15:59:59.844 [main] ERROR c.j.s.ObligationService - An error occurred during the progress
15:59:59.844 [main] DEBUG c.j.s.ObligationService - obligate end...

venality.log:
15:59:59.844 [main] DEBUG c.j.d.ObligationDao - query obligations start...
15:59:59.844 [main] ERROR c.j.d.ObligationDao - An error occurred during the query
15:59:59.844 [main] DEBUG c.j.d.ObligationDao - query obligations end...

二、根据日志级别输出

这里把所有级别为ERROR的日志输出到一个文件中

1. 修改logback(-test).xml文件

serviceAppender和daoAppender都加入以下级别过滤器,这样错误日志就不会在bribery.log和venality.log中打印了:
Xml代码  
  1. <filter class="ch.qos.logback.classic.filter.LevelFilter">  
  2.     <level>ERROR</level>  
  3.     <onMatch>DENY</onMatch>  
  4.     <onMismatch>ACCEPT</onMismatch>  
  5. </filter>  


新建一个错误日志的appender:
Xml代码  
  1. <appender name="errorAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">  
  2.     <file>/logs/error.log</file>  
  3.     <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">  
  4.         <fileNamePattern>/logs/venality-%d{yyyy-MM-dd}.log</fileNamePattern>  
  5.     </rollingPolicy>  
  6.     <encoder>  
  7.         <pattern>%d{HH:mm:ss.SSS} %thread %X{invokeNo} %logger{40} %msg%n</pattern>  
  8.     </encoder>  
  9.     <filter class="ch.qos.logback.classic.filter.LevelFilter"><!-- 只打印错误日志 -->  
  10.         <level>ERROR</level>  
  11.         <onMatch>ACCEPT</onMatch>  
  12.         <onMismatch>DENY</onMismatch>  
  13.     </filter>  
  14. </appender>  


name为com.john.dao和com.john.service的logger都加上errorAppender:
Xml代码  
  1. <appender-ref ref="errorAppender" />  


2. 执行上面的测试方法,service和dao的错误日志都打印到error.log文件中了:
16:12:51,433 main com.john.dao.ObligationDao An error occurred during the query
16:12:51,433 main com.john.service.ObligationService An error occurred during the progress
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
logback日志,及log4jdbc记录数据库日志 -- 步骤
2.日志组件的统一门面
日志框架的体系结构及logback的使用
一个著名的日志系统是怎么设计出来的?
slf4j log4j logback关系详解和相关用法
第009课:Spring Boot 使用slf4j日志记录
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服