zsip.log-spring-boot-starter.1.0.0.Beta1.source-code.logback-spring.xml Maven / Gradle / Ivy
<?xml version="1.0" encoding="UTF-8"?> <configuration> <contextName>${APP_NAME}</contextName> <springProperty name="APP_NAME" scope="context" source="spring.application.name"/> <springProperty name="LOG_PATH" scope="context" source="logging.file.path" defaultValue="./logs"/> <!-- <springProperty name="LOG_POINT_PATH" scope="context" source="logging.file.path" defaultValue="./logs/point"/>--> <!-- <springProperty name="LOG_AUDIT_PATH" scope="context" source="logging.file.path" defaultValue="./logs/audit"/>--> <springProperty name="LOG_MAXFILESIZE" scope="context" source="logback.filesize" defaultValue="50MB"/> <springProperty name="LOG_FILEMAXDAY" scope="context" source="logback.filemaxday" defaultValue="7"/> <springProperty name="ServerIP" scope="context" source="spring.cloud.client.ip-address" defaultValue="0.0.0.0"/> <springProperty name="ServerPort" scope="context" source="server.port" defaultValue="0000"/> <!-- 彩色日志 --> <!-- 彩色日志依赖的渲染类 --> <conversionRule conversionWord="clr" converterClass="org.springframework.boot.logging.logback.ColorConverter" /> <conversionRule conversionWord="wex" converterClass="org.springframework.boot.logging.logback.WhitespaceThrowableProxyConverter" /> <conversionRule conversionWord="wEx" converterClass="org.springframework.boot.logging.logback.ExtendedWhitespaceThrowableProxyConverter" /> <!-- 彩色日志格式 --> <property name="CONSOLE_LOG_PATTERN" value="[${APP_NAME}:${ServerIP}:${ServerPort}] %clr(%d{yyyy-MM-dd HH:mm:ss.SSS}){faint} %clr(%level){blue} %clr(${PID}){magenta} %clr([%X{traceId}]){yellow} %clr([%thread]){orange} %clr(%-40.40logger{39}){cyan} %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}" /> <property name="CONSOLE_LOG_PATTERN_NO_COLOR" value="[${APP_NAME}:${ServerIP}:${ServerPort}] %d{yyyy-MM-dd HH:mm:ss.SSS} %level ${PID} [%X{traceId}] [%thread] %-40.40logger{39} %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}" /> <!-- 控制台日志 --> <appender name="StdoutAppender" class="ch.qos.logback.core.ConsoleAppender"> <withJansi>true</withJansi> <encoder> <pattern>${CONSOLE_LOG_PATTERN}</pattern> <charset>UTF-8</charset> </encoder> </appender> <!-- 按照每天生成常规日志文件 --> <appender name="FileAppender" class="ch.qos.logback.core.rolling.RollingFileAppender"> <file>${LOG_PATH}/application/${APP_NAME}.log</file> <encoder> <pattern>${CONSOLE_LOG_PATTERN_NO_COLOR}</pattern> <charset>UTF-8</charset> </encoder> <!-- 基于时间的分包策略 --> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <fileNamePattern>${LOG_PATH}/application/${APP_NAME}.%d{yyyy-MM-dd}.%i.log</fileNamePattern> <!--保留时间,单位:天--> <maxHistory>${LOG_FILEMAXDAY}</maxHistory> <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP"> <maxFileSize>${LOG_MAXFILESIZE}</maxFileSize> </timeBasedFileNamingAndTriggeringPolicy> </rollingPolicy> <filter class="ch.qos.logback.classic.filter.LevelFilter"> <level>INFO</level> </filter> </appender> <appender name="point_log" class="ch.qos.logback.core.rolling.RollingFileAppender"> <file>${LOG_PATH}/point/point.log</file> <encoder> <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS}|${APP_NAME}|%msg%n</pattern> <charset>UTF-8</charset> </encoder> <!-- 基于时间的分包策略 --> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <fileNamePattern>${LOG_PATH}/point/point.%d{yyyy-MM-dd}.%i.log</fileNamePattern> <!--保留时间,单位:天--> <maxHistory>${LOG_FILEMAXDAY}</maxHistory> <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP"> <maxFileSize>${LOG_MAXFILESIZE}</maxFileSize> </timeBasedFileNamingAndTriggeringPolicy> </rollingPolicy> </appender> <appender name="audit_log" class="ch.qos.logback.core.rolling.RollingFileAppender"> <file>${LOG_PATH}/audit/audit.log</file> <encoder> <pattern>%msg%n</pattern> <charset>UTF-8</charset> </encoder> <!-- 基于时间的分包策略 --> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <fileNamePattern>${LOG_PATH}/audit/audit.%d{yyyy-MM-dd}.%i.log</fileNamePattern> <!--保留时间,单位:天--> <maxHistory>${LOG_FILEMAXDAY}</maxHistory> <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP"> <maxFileSize>${LOG_MAXFILESIZE}</maxFileSize> </timeBasedFileNamingAndTriggeringPolicy> </rollingPolicy> </appender> <appender name="point_log_async" class="ch.qos.logback.classic.AsyncAppender"> <discardingThreshold>0</discardingThreshold> <appender-ref ref="point_log"/> </appender> <appender name="file_async" class="ch.qos.logback.classic.AsyncAppender"> <discardingThreshold>0</discardingThreshold> <appender-ref ref="FileAppender"/> </appender> <appender name="audit_log_async" class="ch.qos.logback.classic.AsyncAppender"> <discardingThreshold>0</discardingThreshold> <appender-ref ref="audit_log"/> </appender> <logger name="com.bizmda.log.monitor" level="debug" addtivity="false"> <appender-ref ref="point_log_async" /> </logger> <logger name="com.bizmda.log.service.impl.LoggerAuditServiceImpl" level="debug" addtivity="false"> <appender-ref ref="audit_log_async" /> </logger> <root level="INFO"> <appender-ref ref="StdoutAppender"/> <appender-ref ref="file_async"/> </root> </configuration>