|
|
<?xml version="1.0" encoding="UTF-8"?>
|
|
|
<configuration scan="true" scanPeriod="30 seconds">
|
|
|
|
|
|
<!-- 定义日志文件保存的路径和文件名 -->
|
|
|
<property name="LOG_PATH" value="./logs"/>
|
|
|
<property name="LOG_FILE" value="${LOG_PATH}/application.log"/>
|
|
|
<property name="LOGBACK_LOG_LEVEL" value="INFO"/>
|
|
|
|
|
|
<!-- 控制台输出,带有颜色 -->
|
|
|
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
|
|
|
<encoder>
|
|
|
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %highlight(%-5level) %cyan(%logger{36}) - %msg%n</pattern>
|
|
|
<charset>UTF-8</charset>
|
|
|
</encoder>
|
|
|
</appender>
|
|
|
|
|
|
<!-- 日志文件输出 -->
|
|
|
<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
|
|
|
<file>${LOG_FILE}</file>
|
|
|
<encoder>
|
|
|
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
|
|
|
<charset>UTF-8</charset>
|
|
|
</encoder>
|
|
|
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
|
|
|
<fileNamePattern>${LOG_PATH}/application/application.%d{yyyy-MM-dd}.log</fileNamePattern>
|
|
|
<maxHistory>30</maxHistory>
|
|
|
<totalSizeCap>100MB</totalSizeCap>
|
|
|
</rollingPolicy>
|
|
|
</appender>
|
|
|
|
|
|
<!-- 异常错误日志单独输出 -->
|
|
|
<appender name="ERROR_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
|
|
|
<file>${LOG_PATH}/error/error.log</file>
|
|
|
<encoder>
|
|
|
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
|
|
|
<charset>UTF-8</charset>
|
|
|
</encoder>
|
|
|
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
|
|
|
<fileNamePattern>${LOG_PATH}/error/error.%d{yyyy-MM-dd}.log</fileNamePattern>
|
|
|
<maxHistory>30</maxHistory>
|
|
|
<totalSizeCap>100MB</totalSizeCap>
|
|
|
</rollingPolicy>
|
|
|
<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
|
|
|
<level>ERROR</level>
|
|
|
</filter>
|
|
|
</appender>
|
|
|
|
|
|
|
|
|
<!-- AOP -->
|
|
|
<appender name="AOP_LOG" class="ch.qos.logback.core.rolling.RollingFileAppender">
|
|
|
<file>${LOG_PATH}/AOP_LOG/AOP_LOG.log</file>
|
|
|
<encoder>
|
|
|
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
|
|
|
<charset>UTF-8</charset>
|
|
|
</encoder>
|
|
|
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
|
|
|
<fileNamePattern>${LOG_PATH}/AOP_LOG/AOP_LOG.%d{yyyy-MM-dd}.log</fileNamePattern>
|
|
|
<maxHistory>30</maxHistory>
|
|
|
<totalSizeCap>100MB</totalSizeCap>
|
|
|
</rollingPolicy>
|
|
|
</appender>
|
|
|
|
|
|
|
|
|
<!-- AOP日志输出到AOP文件,不输出到默认日志 -->
|
|
|
<logger name="com.supervision.ai.service.hub.aop.RequestLogAop" level="INFO" additivity="false">
|
|
|
<appender-ref ref="AOP_LOG"/>
|
|
|
</logger>
|
|
|
|
|
|
<!-- 根日志记录器 -->
|
|
|
<root level="${LOGBACK_LOG_LEVEL}">
|
|
|
<appender-ref ref="CONSOLE"/>
|
|
|
<appender-ref ref="FILE"/>
|
|
|
<appender-ref ref="ERROR_FILE"/>
|
|
|
</root>
|
|
|
</configuration>
|