<?xml version="1.0" encoding="UTF-8"?> <configuration> <!--æ—¥å¿—æ ¼å¼åº”用spring booté»˜è®¤çš„æ ¼å¼ï¼Œä¹Ÿå¯ä»¥è‡ªå·±æ›´æ”¹--> <include resource="org/springframework/boot/logging/logback/defaults.xml"/> <!--å®šä¹‰æ—¥å¿—å˜æ”¾çš„ä½ç½®ï¼Œé»˜è®¤å˜æ”¾åœ¨é¡¹ç›®å¯åŠ¨çš„ç›¸å¯¹è·¯å¾„çš„ç›®å½•--> <springProperty scope="context" name="LOG_PATH" source="log.path" defaultValue="app-log"/> <!-- ****************************************************************************************** --> <!-- ****************************** 本地开å‘åªåœ¨æŽ§åˆ¶å°æ‰“å°æ—¥å¿— ************************************ --> <!-- ****************************************************************************************** --> <springProfile name="local"> <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"> <encoder> <pattern>${CONSOLE_LOG_PATTERN}</pattern> <charset>utf-8</charset> </encoder> </appender> <!--默认所有的包以info--> <root level="info"> <appender-ref ref="STDOUT"/> </root> <!--å„个æœåŠ¡çš„åŒ…åœ¨æœ¬åœ°æ‰§è¡Œçš„æ—¶å€™ï¼Œæ‰“å¼€debug模å¼--> <logger name="cn.stylefeng" level="debug" additivity="false"> <appender-ref ref="STDOUT"/> </logger> </springProfile> <!-- ********************************************************************************************** --> <!-- **** 放到æœåŠ¡å™¨ä¸Šä¸ç®¡åœ¨ä»€ä¹ˆçŽ¯å¢ƒéƒ½åªåœ¨æ–‡ä»¶è®°å½•日志,控制å°ï¼ˆcatalina.out)打å°logbackæ•获ä¸åˆ°çš„æ—¥å¿— **** --> <!-- ********************************************************************************************** --> <springProfile name="!local"> <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"> <encoder> <pattern>${CONSOLE_LOG_PATTERN}</pattern> <charset>utf-8</charset> </encoder> </appender> <!-- 日志记录器,日期滚动记录 --> <appender name="FILE_ERROR" class="ch.qos.logback.core.rolling.RollingFileAppender"> <!-- æ£åœ¨è®°å½•çš„æ—¥å¿—æ–‡ä»¶çš„è·¯å¾„åŠæ–‡ä»¶å --> <file>${LOG_PATH}/log_error.log</file> <!-- 日志记录器的滚动ç–略,按日期,按大å°è®°å½• --> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <!-- 归档的日志文件的路径,%d{yyyy-MM-dd}æŒ‡å®šæ—¥æœŸæ ¼å¼ï¼Œ%i指定索引 --> <fileNamePattern>${LOG_PATH}/error/log-error-%d{yyyy-MM-dd}.%i.log</fileNamePattern> <!-- 除按日志记录之外,还é…置了日志文件ä¸èƒ½è¶…过2M,若超过2M,日志文件会以索引0开始, 命志¥å¿—文件,例如log-error-2013-12-21.0.log --> <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP"> <maxFileSize>10MB</maxFileSize> </timeBasedFileNamingAndTriggeringPolicy> </rollingPolicy> <!-- è¿½åŠ æ–¹å¼è®°å½•日志 --> <append>true</append> <!-- æ—¥å¿—æ–‡ä»¶çš„æ ¼å¼ --> <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder"> <pattern>${FILE_LOG_PATTERN}</pattern> <charset>utf-8</charset> </encoder> <!-- æ¤æ—¥å¿—文件åªè®°å½•error级别的 --> <filter class="ch.qos.logback.classic.filter.LevelFilter"> <level>error</level> <onMatch>ACCEPT</onMatch> <onMismatch>DENY</onMismatch> </filter> </appender> <!-- 日志记录器,日期滚动记录 --> <appender name="FILE_ALL" class="ch.qos.logback.core.rolling.RollingFileAppender"> <!-- æ£åœ¨è®°å½•çš„æ—¥å¿—æ–‡ä»¶çš„è·¯å¾„åŠæ–‡ä»¶å --> <file>${LOG_PATH}/log_total.log</file> <!-- 日志记录器的滚动ç–略,按日期,按大å°è®°å½• --> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <!-- 归档的日志文件的路径,%d{yyyy-MM-dd}æŒ‡å®šæ—¥æœŸæ ¼å¼ï¼Œ%i指定索引 --> <fileNamePattern>${LOG_PATH}/total/log-total-%d{yyyy-MM-dd}.%i.log</fileNamePattern> <!-- 除按日志记录之外,还é…置了日志文件ä¸èƒ½è¶…过2M,若超过2M,日志文件会以索引0开始, 命志¥å¿—文件,例如log-error-2013-12-21.0.log --> <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP"> <maxFileSize>10MB</maxFileSize> </timeBasedFileNamingAndTriggeringPolicy> </rollingPolicy> <!-- è¿½åŠ æ–¹å¼è®°å½•日志 --> <append>true</append> <!-- æ—¥å¿—æ–‡ä»¶çš„æ ¼å¼ --> <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder"> <pattern>${FILE_LOG_PATTERN}</pattern> <charset>utf-8</charset> </encoder> </appender> <!--记录到文件时,记录两类一类是error日志,一个是所有日志--> <root level="info"> <appender-ref ref="STDOUT"/> <appender-ref ref="FILE_ERROR"/> <appender-ref ref="FILE_ALL"/> </root> </springProfile> </configuration>