|
@@ -1,129 +1,134 @@
|
|
|
<?xml version="1.0" encoding="UTF-8"?>
|
|
|
<configuration>
|
|
|
- <property name="log.path" value="./logs"/>
|
|
|
- <property name="console.log.pattern"
|
|
|
- value="%red(%d{yyyy-MM-dd HH:mm:ss}) %green([%thread]) %highlight(%-5level) %boldMagenta(%logger{36}%n) - %msg%n"/>
|
|
|
- <property name="log.pattern" value="%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n"/>
|
|
|
-
|
|
|
- <!-- 控制台输出 -->
|
|
|
- <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
|
|
|
- <encoder>
|
|
|
- <pattern>${console.log.pattern}</pattern>
|
|
|
- <charset>utf-8</charset>
|
|
|
- </encoder>
|
|
|
- </appender>
|
|
|
-
|
|
|
- <!-- 控制台输出 -->
|
|
|
- <appender name="file_console" class="ch.qos.logback.core.rolling.RollingFileAppender">
|
|
|
- <file>${log.path}/sys-console.log</file>
|
|
|
- <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
|
|
|
- <!-- 日志文件名格式 -->
|
|
|
- <fileNamePattern>${log.path}/sys-console.%d{yyyy-MM-dd}.log</fileNamePattern>
|
|
|
- <!-- 日志最大 1天 -->
|
|
|
- <maxHistory>1</maxHistory>
|
|
|
- </rollingPolicy>
|
|
|
- <encoder>
|
|
|
- <pattern>${log.pattern}</pattern>
|
|
|
- <charset>utf-8</charset>
|
|
|
- </encoder>
|
|
|
- <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
|
|
|
- <!-- 过滤的级别 -->
|
|
|
- <level>INFO</level>
|
|
|
- </filter>
|
|
|
- </appender>
|
|
|
-
|
|
|
- <!-- 系统日志输出 -->
|
|
|
- <appender name="file_info" class="ch.qos.logback.core.rolling.RollingFileAppender">
|
|
|
- <file>${log.path}/sys-info.log</file>
|
|
|
- <!-- 循环政策:基于时间创建日志文件 -->
|
|
|
- <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
|
|
|
- <!-- 日志文件名格式 -->
|
|
|
- <fileNamePattern>${log.path}/sys-info.%d{yyyy-MM-dd}.log</fileNamePattern>
|
|
|
- <!-- 日志最大的历史 60天 -->
|
|
|
- <maxHistory>60</maxHistory>
|
|
|
- </rollingPolicy>
|
|
|
- <encoder>
|
|
|
- <pattern>${log.pattern}</pattern>
|
|
|
- </encoder>
|
|
|
- <filter class="ch.qos.logback.classic.filter.LevelFilter">
|
|
|
- <!-- 过滤的级别 -->
|
|
|
- <level>INFO</level>
|
|
|
- <!-- 匹配时的操作:接收(记录) -->
|
|
|
- <onMatch>ACCEPT</onMatch>
|
|
|
- <!-- 不匹配时的操作:拒绝(不记录) -->
|
|
|
- <onMismatch>DENY</onMismatch>
|
|
|
- </filter>
|
|
|
- </appender>
|
|
|
-
|
|
|
- <appender name="file_error" class="ch.qos.logback.core.rolling.RollingFileAppender">
|
|
|
- <file>${log.path}/sys-error.log</file>
|
|
|
- <!-- 循环政策:基于时间创建日志文件 -->
|
|
|
- <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
|
|
|
- <!-- 日志文件名格式 -->
|
|
|
- <fileNamePattern>${log.path}/sys-error.%d{yyyy-MM-dd}.log</fileNamePattern>
|
|
|
- <!-- 日志最大的历史 60天 -->
|
|
|
- <maxHistory>60</maxHistory>
|
|
|
- </rollingPolicy>
|
|
|
- <encoder>
|
|
|
- <pattern>${log.pattern}</pattern>
|
|
|
- </encoder>
|
|
|
- <filter class="ch.qos.logback.classic.filter.LevelFilter">
|
|
|
- <!-- 过滤的级别 -->
|
|
|
- <level>ERROR</level>
|
|
|
- <!-- 匹配时的操作:接收(记录) -->
|
|
|
- <onMatch>ACCEPT</onMatch>
|
|
|
- <!-- 不匹配时的操作:拒绝(不记录) -->
|
|
|
- <onMismatch>DENY</onMismatch>
|
|
|
- </filter>
|
|
|
- </appender>
|
|
|
-
|
|
|
- <!-- info异步输出 -->
|
|
|
- <appender name="async_info" class="ch.qos.logback.classic.AsyncAppender">
|
|
|
- <!-- 不丢失日志.默认的,如果队列的80%已满,则会丢弃TRACT、DEBUG、INFO级别的日志 -->
|
|
|
- <discardingThreshold>0</discardingThreshold>
|
|
|
- <!-- 更改默认的队列的深度,该值会影响性能.默认值为256 -->
|
|
|
- <queueSize>512</queueSize>
|
|
|
- <!-- 添加附加的appender,最多只能添加一个 -->
|
|
|
- <appender-ref ref="file_info"/>
|
|
|
- </appender>
|
|
|
-
|
|
|
- <!-- error异步输出 -->
|
|
|
- <appender name="async_error" class="ch.qos.logback.classic.AsyncAppender">
|
|
|
- <!-- 不丢失日志.默认的,如果队列的80%已满,则会丢弃TRACT、DEBUG、INFO级别的日志 -->
|
|
|
- <discardingThreshold>0</discardingThreshold>
|
|
|
- <!-- 更改默认的队列的深度,该值会影响性能.默认值为256 -->
|
|
|
- <queueSize>512</queueSize>
|
|
|
- <!-- 添加附加的appender,最多只能添加一个 -->
|
|
|
- <appender-ref ref="file_error"/>
|
|
|
- </appender>
|
|
|
-
|
|
|
- <!-- 整合 skywalking 控制台输出 tid -->
|
|
|
- <!-- <appender name="console" class="ch.qos.logback.core.ConsoleAppender">-->
|
|
|
- <!-- <encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">-->
|
|
|
- <!-- <layout class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.TraceIdPatternLogbackLayout">-->
|
|
|
- <!-- <pattern>[%tid] ${console.log.pattern}</pattern>-->
|
|
|
- <!-- </layout>-->
|
|
|
- <!-- <charset>utf-8</charset>-->
|
|
|
- <!-- </encoder>-->
|
|
|
- <!-- </appender>-->
|
|
|
-
|
|
|
- <!-- 整合 skywalking 推送采集日志 -->
|
|
|
- <!-- <appender name="sky_log" class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.log.GRPCLogClientAppender">-->
|
|
|
- <!-- <encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">-->
|
|
|
- <!-- <layout class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.TraceIdPatternLogbackLayout">-->
|
|
|
- <!-- <pattern>[%tid] ${console.log.pattern}</pattern>-->
|
|
|
- <!-- </layout>-->
|
|
|
- <!-- <charset>utf-8</charset>-->
|
|
|
- <!-- </encoder>-->
|
|
|
- <!-- </appender>-->
|
|
|
-
|
|
|
- <!--系统操作日志-->
|
|
|
- <root level="info">
|
|
|
- <appender-ref ref="console"/>
|
|
|
- <appender-ref ref="async_info"/>
|
|
|
- <appender-ref ref="async_error"/>
|
|
|
- <appender-ref ref="file_console"/>
|
|
|
- <!-- <appender-ref ref="sky_log"/>-->
|
|
|
- </root>
|
|
|
-
|
|
|
-</configuration>
|
|
|
+
|
|
|
+ <!--日志格式应用spring boot默认的格式,也可以自己更改-->
|
|
|
+ <include resource="org/springframework/boot/logging/logback/defaults.xml"/>
|
|
|
+
|
|
|
+ <!--定义日志存放的位置,默认存放在项目启动的相对路径的目录-->
|
|
|
+ <springProperty scope="context" name="LOG_PATH" source="spring.application.name"/>
|
|
|
+
|
|
|
+ <!-- 控制台日志打印格式 -->
|
|
|
+ <property name="CONSOLE_LOG_PATTERN"
|
|
|
+ value="%clr(%d{${LOG_DATEFORMAT_PATTERN:-yyyy-MM-dd HH:mm:ss}}){faint} %clr(${LOG_LEVEL_PATTERN:-%5p}) %clr(${PID:- }){magenta} %clr(---){faint} %clr(${LOGGED_APPLICATION_NAME:-}[%15.15t]){faint} %clr(${LOG_CORRELATION_PATTERN:-}){faint}%clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}"/>
|
|
|
+
|
|
|
+ <!--本地开发只在控制台打印日志-->
|
|
|
+ <springProfile name="dev">
|
|
|
+
|
|
|
+ <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="com.fly" level="info" additivity="false">
|
|
|
+ <appender-ref ref="STDOUT"/>
|
|
|
+ </logger>
|
|
|
+
|
|
|
+ </springProfile>
|
|
|
+
|
|
|
+ <!-- 放到服务器上不管在什么环境都只在文件记录日志,控制台(catalina.out)打印logback捕获不到的日志 -->
|
|
|
+ <springProfile name="!dev">
|
|
|
+
|
|
|
+ <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}-log/error/error-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
|
|
|
+
|
|
|
+ <!--
|
|
|
+ 配置了日志文件不能超过10M
|
|
|
+ 若超过10M,日志文件会以索引0开始,命名日志文件,例如log-error-2013-12-21.0.log
|
|
|
+ -->
|
|
|
+ <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
|
|
|
+ <maxFileSize>10MB</maxFileSize>
|
|
|
+ </timeBasedFileNamingAndTriggeringPolicy>
|
|
|
+
|
|
|
+ <!-- 日志最大的历史30天 -->
|
|
|
+ <maxHistory>30</maxHistory>
|
|
|
+
|
|
|
+ </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}-log/total/total-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
|
|
|
+
|
|
|
+ <!--
|
|
|
+ 配置了日志文件不能超过10M
|
|
|
+ 若超过10M,日志文件会以索引0开始,命名日志文件,例如log-error-2013-12-21.0.log
|
|
|
+ -->
|
|
|
+ <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
|
|
|
+ <maxFileSize>10MB</maxFileSize>
|
|
|
+ </timeBasedFileNamingAndTriggeringPolicy>
|
|
|
+
|
|
|
+ <!-- 日志最大的历史 30天 -->
|
|
|
+ <maxHistory>30</maxHistory>
|
|
|
+
|
|
|
+ </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>
|