文档章节

logback系列之四:输出日志到不同文件

小代码2016
 小代码2016
发布于 2016/03/25 11:38
字数 602
阅读 318
收藏 5
点赞 1
评论 0
为了方便查看和归档: 
不同包的日志可能要放到不同的文件中,如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

本文转载自:http://czj4451.iteye.com/blog/1984259

共有 人打赏支持
小代码2016
粉丝 35
博文 311
码字总数 153495
作品 0
安阳
程序员

暂无相关文章

vbs 取文件大小 字节

dim namedim fs, s'name = Inputbox("姓名")'msgbox(name)set fs = wscript.createobject("scripting.filesystemobject") 'fs为FSO实例if (fs.folderexists("c:\temp"))......

vga ⋅ 12分钟前 ⋅ 1

高并发之Nginx的限流

首先Nginx的版本号有要求,最低为1.11.5 如果低于这个版本,在Nginx的配置中 upstream web_app { server 到达Ip1:端口 max_conns=10; server 到达Ip2:端口 max_conns=10; } server { listen ...

算法之名 ⋅ 今天 ⋅ 0

Spring | IOC AOP 注解 简单使用

写在前面的话 很久没更新笔记了,有人会抱怨:小冯啊,你是不是在偷懒啊,没有学习了。老哥,真的冤枉:我觉得我自己很菜,还在努力学习呢,正在学习Vue.js做管理系统呢。即便这样,我还是不...

Wenyi_Feng ⋅ 今天 ⋅ 0

博客迁移到 https://www.jianshu.com/u/aa501451a235

博客迁移到 https://www.jianshu.com/u/aa501451a235 本博客不再更新

为为02 ⋅ 今天 ⋅ 0

win10怎么彻底关闭自动更新

win10自带的更新每天都很多,每一次下载都要占用大量网络,而且安装要等得时间也蛮久的。 工具/原料 Win10 方法/步骤 单击左下角开始菜单点击设置图标进入设置界面 在设置窗口中输入“服务”...

阿K1225 ⋅ 今天 ⋅ 0

Elasticsearch 6.3.0 SQL功能使用案例分享

The best elasticsearch highlevel java rest api-----bboss Elasticsearch 6.3.0 官方新推出的SQL检索插件非常不错,本文一个实际案例来介绍其使用方法。 1.代码中的sql检索 @Testpu...

bboss ⋅ 今天 ⋅ 0

informix数据库在linux中的安装以及用java/c/c++访问

一、安装前准备 安装JDK(略) 到IBM官网上下载informix软件:iif.12.10.FC9DE.linux-x86_64.tar放在某个大家都可以访问的目录比如:/mypkg,并解压到该目录下。 我也放到了百度云和天翼云上...

wangxuwei ⋅ 今天 ⋅ 0

PHP语言系统ZBLOG或许无法重现月光博客的闪耀历史[图]

最近在写博客,希望通过自己努力打造一个优秀的教育类主题博客,名动江湖,但是问题来了,现在写博客还有前途吗?面对强大的自媒体站点围剿,还有信心和可能型吗? 至于程序部分,我选择了P...

原创小博客 ⋅ 今天 ⋅ 0

IntelliJ IDEA 2018.1新特性

工欲善其事必先利其器,如果有一款IDE可以让你更高效地专注于开发以及源码阅读,为什么不试一试? 本文转载自:netty技术内幕 3月27日,jetbrains正式发布期待已久的IntelliJ IDEA 2018.1,再...

Romane ⋅ 今天 ⋅ 0

浅谈设计模式之工厂模式

工厂模式(Factory Pattern)是 Java 中最常用的设计模式之一。这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。 在工厂模式中,我们在创建对象时不会对客户端暴露创建逻...

佛系程序猿灬 ⋅ 今天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部