spring cloud 日志配置

Spring Cloud日志配置可以使用Log4j或者logback,但是官方推荐使用logback。logback是log4j作者出的,用来替代log4j的。我们也使用logback来处理日志

 

在spring boot项目里面 需要配置logback是非常简单的。

第一步确认依赖包里面有logback的包,我这里引入的是spring-cloud-starter-sleuth包,它里面已经集成了logback的包

111533_ST5E_3226688.png

 

下一步我们在配置文件中加入相关配置信息。在bootstrap.properties中加入下面的配置log的文件位置。

logging.file=logs/${spring.application.name}.log

 

就这么简单。 下面我们直接运行程序,就会在项目目录下生成相关的日志文件(logs/应用名.log)

111633_xDCh_3226688.png

下一步我们还可以控制,日志级别,如下图所示我们控制的日志级别为info,日志级别可根据自己的需求进行配置

logging.level.org.springframework.boot=info

 

如果这种默认日志配置不能满足需求,那我们可以配置logback-spring.xml,这个logback-spring.xml项目启动的时候是默认读取的。在这个xml里面 我们可以根据自己的需求进行配置

我这个logback-spring.xml配置的大概功能是记录日志,当日志大于10MB时,就自动分出去,并在文件名上加上了时间。

${LOG_FILE}是读取properties里面的logging.file的值

111730_f15h_3226688.png

111753_fi8H_3226688.png

<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>

除此之外还有一些资料。

111824_j7Nz_3226688.png

<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>

 

 

 

 

转载于:https://my.oschina.net/u/3226688/blog/904200

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值