logback之四:输出日志到不同文件
来源:互联网 发布:淘宝吧 编辑:程序博客网 时间:2024/05/23 01:22
为了方便查看和归档:
不同包的日志可能要放到不同的文件中,如service层和dao层的日志;
不同日志级别:调试、信息、警告和错误等也要分文件输出。
一、根据包输出,通过logger的name属性指定不同的包
1. 创建不同包下的两个类:
2. 在logback(-test).xml中添加:
在类路径下创建Spring的beans.xml文件:(beans节点省略)
3. 测试方法:
执行测试后,
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中打印了:
新建一个错误日志的appender:
name为com.john.dao和com.john.service的logger都加上errorAppender:
2. 执行上面的测试方法,service和dao的错误日志都打印到error.log文件中了:
16:12:51,433 main com.john.dao.ObligationDao An error occurred during the query
不同包的日志可能要放到不同的文件中,如service层和dao层的日志;
不同日志级别:调试、信息、警告和错误等也要分文件输出。
一、根据包输出,通过logger的name属性指定不同的包
1. 创建不同包下的两个类:
- package com.john.service;
- @Service
- public class ObligationService {
- static final Logger log = LoggerFactory.getLogger(ObligationService.class);
- @Resource
- ObligationDao dao;
- public void obligate() {
- log.debug("obligate start...");
- dao.queryObligations();
- log.error("An error occurred during the progress");
- log.debug("obligate end...");
- }
- }
- package com.john.dao;
- @Repository
- public class ObligationDao {
- static final Logger log = LoggerFactory.getLogger(ObligationDao.class);
- public void queryObligations() {
- log.debug("query obligations start...");
- log.error("An error occurred during the query");
- log.debug("query obligations end...");
- }
- }
2. 在logback(-test).xml中添加:
- <appender name="serviceAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">
- <file>/logs/bribery.log</file>
- <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
- <fileNamePattern>/logs/bribery-%d{yyyy-MM-dd}.log</fileNamePattern>
- </rollingPolicy>
- <encoder>
- <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{5} - %msg%n</pattern>
- </encoder>
- </appender>
- <appender name="daoAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">
- <file>/logs/venality.log</file>
- <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
- <fileNamePattern>/logs/venality-%d{yyyy-MM-dd}.log</fileNamePattern>
- </rollingPolicy>
- <encoder>
- <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{5} - %msg%n</pattern>
- </encoder>
- </appender>
- <logger name="com.john.service" level="DEBUG" additivity="false">
- <appender-ref ref="serviceAppender" />
- </logger>
- <logger name="com.john.dao" level="DEBUG" additivity="false">
- <appender-ref ref="daoAppender" />
- </logger>
在类路径下创建Spring的beans.xml文件:(beans节点省略)
- <context:component-scan base-package="com.john" />
3. 测试方法:
- @Test
- public void dispatchByPackageTest() {
- AbstractApplicationContext ctx = new ClassPathXmlApplicationContext("beans.xml");
- ObligationService service = ctx.getBean(ObligationService.class);
- service.obligate();
- }
执行测试后,
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中打印了:
- <filter class="ch.qos.logback.classic.filter.LevelFilter">
- <level>ERROR</level>
- <onMatch>DENY</onMatch>
- <onMismatch>ACCEPT</onMismatch>
- </filter>
新建一个错误日志的appender:
- <appender name="errorAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">
- <file>/logs/error.log</file>
- <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
- <fileNamePattern>/logs/venality-%d{yyyy-MM-dd}.log</fileNamePattern>
- </rollingPolicy>
- <encoder>
- <pattern>%d{HH:mm:ss.SSS} %thread %X{invokeNo} %logger{40} %msg%n</pattern>
- </encoder>
- <filter class="ch.qos.logback.classic.filter.LevelFilter"><!-- 只打印错误日志 -->
- <level>ERROR</level>
- <onMatch>ACCEPT</onMatch>
- <onMismatch>DENY</onMismatch>
- </filter>
- </appender>
name为com.john.dao和com.john.service的logger都加上errorAppender:
- <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
阅读全文
0 0
- logback系列之四:输出日志到不同文件
- logback系列之四:输出日志到不同文件
- logback之四:输出日志到不同文件
- logback系列之二:输出日志到文件
- logback系列之三:输出日志到文件(滚动)
- logback之三:输出日志到文件(滚动)
- logback日志输出不同级别到不同文件(开发实例配置)
- logback 配置 不同level日志输出到不同文件 按天 大小拆分
- 配置logback将日志输出到文件
- logback 日志不输出到指定文件
- logback之二:输出日志到控制台
- logback 根据不同业务打印日志到不同的文件
- logback不同业务的日志打印到不同文件
- slf4j+logback实现日志存放到不同文件
- logback 配置不同级别日志输出
- logback之sql单纯输出到一个日志,所有日志输入到一个日志
- 使log4j不同level的日志输出到不同文件
- log4j不同的日志输出到不同的文件中
- Angular 导出Excel 表格
- C++ 中引用(reference)和指针的区别
- 进程间通信(IPC)3 ------ 消息队列
- FreeBASIC学习笔记——8.2 指针的类型与运算
- ASP.NET C#根据HTML页面导出PDF
- logback之四:输出日志到不同文件
- 请放下你的无效社交
- NIFI 系统属性 System Properties之ZooKeeper Properties
- spring4与Thymeleaf整合一个简单示例
- Redis常用数据类型
- 小朋友学C++(10):子类构造函数调用父类构造函数
- 蓝桥杯ALGO-1区间K大数
- windows bat 进入或跳转到其它目录命令
- 用jQuery的tab实现简单仿微博网页