<?xml version="1.0" encoding="UTF-8"?>
|
<!DOCTYPE configuration>
|
<configuration>
|
<!--引用默认日志配置-->
|
<include resource="org/springframework/boot/logging/logback/defaults.xml"/>
|
<!--使用默认的控制台日志输出实现-->
|
<include resource="org/springframework/boot/logging/logback/console-appender.xml"/>
|
<!--应用名称-->
|
<springProperty scope="context" name="APP_NAME" source="spring.application.name" defaultValue="springBoot"/>
|
<!-- 日志输出格式 -->
|
<property name="log.pattern"
|
value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level [%X{requestId}] [%X{clientIP}] [%X{userId}] - [%C,%M,%L] - %msg%n"/>
|
|
<property name="log.path" value="logs"/>
|
<!--日志文件保存路径-->
|
<property name="LOG_FILE_PATH" value="${LOG_FILE:-${LOG_PATH:-${LOG_TEMP:-${java.io.tmpdir:-/tmp}}}/logs}"/>
|
<!--LogStash访问host-->
|
<springProperty name="LOG_STASH_HOST" scope="context" source="logstash.host" defaultValue="localhost"/>
|
<!--是否开启LogStash插件内部日志-->
|
<springProperty name="ENABLE_INNER_LOG" scope="context" source="logstash.enableInnerLog" defaultValue="false"/>
|
|
|
<!-- 控制台输出 -->
|
<appender name="console" class="ch.qos.logback.core.ConsoleAppender">
|
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
|
<pattern>${log.pattern}</pattern>
|
<charset>utf8</charset>
|
</encoder>
|
</appender>
|
|
<!-- 系统日志输出 -->
|
<appender name="file_info" class="ch.qos.logback.core.rolling.RollingFileAppender">
|
<!-- <file>${log.path}/zero-spring-info.log</file>-->
|
<!-- 循环政策:基于时间创建日志文件 -->
|
<!-- <file>-->
|
<!-- logs/zero-spring.log-->
|
<!-- </file>-->
|
<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
|
<!-- 日志文件名格式 -->
|
<fileNamePattern>${log.path}/${APP_NAME}-info-%d{yyyy-MM-dd}-%i.log</fileNamePattern>
|
<totalSizeCap>30GB</totalSizeCap>
|
<!--设置日志文件大小,超过就重新生成文件,默认50M-->
|
<maxFileSize>100MB</maxFileSize>
|
<!-- 日志最大的历史 30天 -->
|
<maxHistory>30</maxHistory>
|
</rollingPolicy>
|
<encoder>
|
<pattern>${log.pattern}</pattern>
|
<charset>UTF-8</charset>
|
</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}/zero-spring-error.log</file>-->
|
<!-- 循环政策:基于时间创建日志文件 -->
|
<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
|
<!-- 日志文件名格式 -->
|
<fileNamePattern>${log.path}/${APP_NAME}-error-%d{yyyy-MM-dd}-%i.log</fileNamePattern>
|
<totalSizeCap>10GB</totalSizeCap>
|
<!--设置日志文件大小,超过就重新生成文件,默认50M-->
|
<maxFileSize>100MB</maxFileSize>
|
<!-- 日志最大的历史 30天 -->
|
<maxHistory>30</maxHistory>
|
</rollingPolicy>
|
<encoder>
|
<pattern>${log.pattern}</pattern>
|
<charset>UTF-8</charset>
|
</encoder>
|
<filter class="ch.qos.logback.classic.filter.LevelFilter">
|
<!-- 过滤的级别 -->
|
<level>ERROR</level>
|
<!-- 匹配时的操作:接收(记录) -->
|
<onMatch>ACCEPT</onMatch>
|
<!-- 不匹配时的操作:拒绝(不记录) -->
|
<onMismatch>DENY</onMismatch>
|
</filter>
|
</appender>
|
|
|
<!--控制框架输出日志-->
|
<logger name="org.slf4j" level="INFO"/>
|
<logger name="springfox" level="INFO"/>
|
<logger name="io.swagger" level="INFO"/>
|
<logger name="org.springframework" level="INFO"/>
|
<logger name="org.hibernate.validator" level="INFO"/>
|
|
<root level="INFO">
|
<!-- <appender-ref ref="console"/>-->
|
<appender-ref ref="file_info"/>
|
<appender-ref ref="file_error"/>
|
</root>
|
|
|
<root level="DEBUG">
|
<appender-ref ref="console"/>
|
</root>
|
</configuration>
|