環境:
springboot + spring-cloud-starter-sleuth + logback
logback.xml示例:
<?xml version="1.0" encoding="UTF-8"?> <configuration scan="true" scanPeriod="10 seconds"> <!--定義日志文件的存儲地址 勿在 LogBack 的配置中使用相對路徑--> <property name="LOG_HOME" value="./log" /> <property name="APP_NAME" value="boot" /> <!-- 控制台輸出 --> <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"> <encoder> <pattern>%d{HH:mm:ss.SSS} [%X{traceId}-%X{X-B3-TraceId}] [%thread] %-5level %logger{50} - %msg%n</pattern> </encoder> </appender> <root level="INFO"> <appender-ref ref="STDOUT" /> </root> <!-- 按照每天生成日志文件 --> <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <FileNamePattern>${LOG_HOME}/%d{yyyy-MM-dd}/${APP_NAME}.%d{yyyy-MM-dd}.log</FileNamePattern> <MaxHistory>1</MaxHistory> </rollingPolicy> <encoder> <pattern>%d{HH:mm:ss.SSS} [%X{traceId}-%X{X-B3-TraceId}] [%thread] %-5level %logger{50} - %msg%n</pattern> </encoder> </appender> <appender name="ASYNC" class="ch.qos.logback.classic.AsyncAppender"> <appender-ref ref="FILE" /> <queueSize>512</queueSize> <discardingThreshold>0</discardingThreshold> </appender> <logger name="com.boot.core" level="info"> <appender-ref ref="ASYNC" /> </logger> <appender name="VISIT_LOG" class="ch.qos.logback.core.rolling.RollingFileAppender"> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <FileNamePattern>${LOG_HOME}/%d{yyyy-MM-dd}/${APP_NAME}.%d{yyyy-MM-dd}.visit.log</FileNamePattern> <MaxHistory>1</MaxHistory> </rollingPolicy> <encoder> <pattern>%d{HH:mm:ss.SSS} [%X{traceId}-%X{X-B3-TraceId}] [%thread] %-5level %logger{50} - %msg%n</pattern> </encoder> </appender> <appender name="VISIT_ASYNC" class="ch.qos.logback.classic.AsyncAppender"> <appender-ref ref="VISIT_LOG" /> <queueSize>512</queueSize> <discardingThreshold>0</discardingThreshold> </appender> <logger name="com.boot.code" level="info"> <appender-ref ref="VISIT_ASYNC" /> </logger> </configuration>
上面截圖代碼中logger標簽中name屬性可以包路徑也可以是類路徑,如果是包路徑把該包下的所有打印的日志放到箭頭所指的文件中,如果是類的全路徑亦然。
其中的[%X{traceId}-%X{X-B3-TraceId}] 為鏈路追蹤號:
日志級別:
等級由低到高:debug<info<warn<Error<Fatal;
等級越低打印的信息越全(debug文件里有info文件的信息)
代碼參考:https://github.com/Pinshuducha/boot