slf4j+logback實現日誌存放到不同檔案
阿新 • • 發佈:2018-10-31
為了方便檢視和歸檔:
不同包的日誌可能要放到不同的檔案中,如service層和dao層的日誌;
不同日誌級別:除錯、資訊、警告和錯誤等也要分檔案輸出。
一、根據包輸出,通過logger的name屬性指定不同的包
1. 建立不同包下的兩個類:
Java程式碼
Java程式碼
2. 在logback(-test).xml中新增:
Xml程式碼
3. 測試方法:
Java程式碼
執行測試後,
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程式碼
新建一個錯誤日誌的appender:
Xml程式碼
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. 建立不同包下的兩個類:
Java程式碼
- 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...");
- }
- }
Java程式碼
- 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中新增:
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>
3. 測試方法:
Java程式碼
- @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中列印了:
Xml程式碼
- <filter class="ch.qos.logback.classic.filter.LevelFilter">
- <level>ERROR</level>
- <onMatch>DENY</onMatch>
- <onMismatch>ACCEPT</onMismatch>
- </filter>
新建一個錯誤日誌的appender:
Xml程式碼
- <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>
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