Spring Cloud日志配置可以使用Log4j或者logback,但是官方推荐使用logback。logback是log4j作者出的,用来替代log4j的。我们也使用logback来处理日志
在spring boot项目里面 需要配置logback是非常简单的。
第一步确认依赖包里面有logback的包,我这里引入的是spring-cloud-starter-sleuth包,它里面已经集成了logback的包
下一步我们在配置文件中加入相关配置信息。在bootstrap.properties中加入下面的配置log的文件位置。
logging.file=logs/${spring.application.name}.log
就这么简单。 下面我们直接运行程序,就会在项目目录下生成相关的日志文件(logs/应用名.log)
下一步我们还可以控制,日志级别,如下图所示我们控制的日志级别为info,日志级别可根据自己的需求进行配置
logging.level.org.springframework.boot=info
如果这种默认日志配置不能满足需求,那我们可以配置logback-spring.xml,这个logback-spring.xml项目启动的时候是默认读取的。在这个xml里面 我们可以根据自己的需求进行配置
我这个logback-spring.xml配置的大概功能是记录日志,当日志大于10MB时,就自动分出去,并在文件名上加上了时间。
${LOG_FILE}是读取properties里面的logging.file的值
<configuration>
<springProperty scope="context" name="app_name" source="spring.application.name" />
<include resource="org/springframework/boot/logging/logback/defaults.xml"/>
<include resource="org/springframework/boot/logging/logback/console-appender.xml"/>
<jmxConfigurator/>
<appender name="rollingFile" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${LOG_FILE}</file>
<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
<fileNamePattern>${LOG_FILE}.%d{yyyy-MM-dd}.%i</fileNamePattern>
<MaxFileSize>10MB</MaxFileSize>
</rollingPolicy>
<encoder>
<pattern>%d{yyyy-MM-dd} %d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
</encoder>
</appender>
<root level="INFO">
<appender-ref ref="rollingFile"/>
<appender-ref ref="CONSOLE"/>
</root>
</configuration>
除此之外还有一些资料。
<configuration>
<springProperty scope="context" name="app_name" source="spring.application.name" />
<include resource="org/springframework/boot/logging/logback/defaults.xml"/>
<property name="LOG_FILE" value="${LOG_FILE:-${LOG_PATH:-${LOG_TEMP:-/logs}}/app.log}"/>
<include resource="org/springframework/boot/logging/logback/console-appender.xml"/>
<springProfile name="default">
<root level="INFO">
<appender-ref ref="CONSOLE"/>
</root>
</springProfile>
<jmxConfigurator/>
<springProfile name="test,prod">
<appender name="rollingFile"
class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${LOG_PATH}/${LOG_FILE}</file>
<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
<fileNamePattern>${LOG_PATH}/${LOG_FILE}.%d{yyyy-MM-dd}.%i</fileNamePattern>
<MaxFileSize>10MB</MaxFileSize>
</rollingPolicy>
<!--<encoder class="net.logstash.logback.encoder.LogstashEncoder">-->
<!--<includeCallerInfo>true</includeCallerInfo>-->
<!--</encoder>-->
<encoder class="net.logstash.logback.encoder.LoggingEventCompositeJsonEncoder">
<providers>
<timestamp>
<timeZone>UTC</timeZone>
</timestamp>
<pattern>
<pattern>
{
"severity": "%level",
"service": "${app_name:-}",
"trace": "%X{X-B3-TraceId:-}",
"span": "%X{X-B3-SpanId:-}",
"exportable": "%X{X-Span-Export:-}",
"pid": "${PID:-}",
"thread": "%thread",
"class": "%logger{40}",
"rest": "%message"
}
</pattern>
</pattern>
</providers>
</encoder>
</appender>
<root level="INFO">
<appender-ref ref="rollingFile"/>
<appender-ref ref="CONSOLE"/>
</root>
</springProfile>
</configuration>