继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

Spring Boot日志配置

所谓伊人_在水一方
关注TA
已关注
手记 273
粉丝 23
获赞 169

支持日志框架Java Util Logging, Log4J2 and Logback,默认是使用logback  
配置方式:默认配置文件配置和引用外部配置文件配置

1、默认配置文件配置

  • 不建议使用:不够灵活,对log4j2等不够友好

    # 日志文件名,比如:roncoo.log,或者是 /var/log/roncoo.loglogging.file=roncoo.log # 日志级别配置,比如: logging.level.org.springframework=DEBUGlogging.level.*=infologging.level.org.springframework=DEBUG

2、配置logback

  • 引用外部配置文件

    spring boot默认会加载classpath:logback-spring.xml或者classpath:logback-spring.groovy。  
    使用自定义配置文件,配置方式为:logging.config=classpath:logback-roncoo.xml;注意:不要使用logback这个来命名,否则spring boot将不能完全实例化。

    ① 使用基于spring boot的配置

    <?xml version="1.0" encoding="UTF-8"?><configuration><include resource="org/springframework/boot/logging/logback/base.xml"/><logger name="org.springframework.web" level="DEBUG"/></configuration>

    ② 自定义配置

    <?xml version="1.0" encoding="UTF-8"?><configuration>    <!-- 文件输出格式 -->    <property name="PATTERN" value="%-12(%d{yyyy-MM-dd HH:mm:ss.SSS}) |-%-5level [%thread] %c [%L] -| %msg%n" />    <!-- test文件路径 -->    <property name="TEST_FILE_PATH" value="logs/info" />    <!-- pro文件路径 -->    <property name="PRO_FILE_PATH" value="logs/warn" />    <!-- 开发环境 -->    <springProfile name="dev">        <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">            <encoder>                <pattern>${PATTERN}</pattern>            </encoder>        </appender>        <logger name="com.roncoo.education" level="debug"/>        <root level="info">            <appender-ref ref="CONSOLE" />        </root>    </springProfile>    <!-- 测试环境 -->    <springProfile name="test">        <!-- 每天产生一个文件 -->        <appender name="TEST-FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">            <!-- 文件路径 -->            <file>${TEST_FILE_PATH}</file>            <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">                <!-- 文件名称 -->                <fileNamePattern>${TEST_FILE_PATH}.%d{yyyy-MM-dd}.log</fileNamePattern>                <!-- 文件最大保存历史数量 -->                <MaxHistory>100</MaxHistory>            </rollingPolicy>            <layout class="ch.qos.logback.classic.PatternLayout">                <pattern>${PATTERN}</pattern>            </layout>        </appender>        <root level="info">            <appender-ref ref="TEST-FILE" />        </root>    </springProfile>    <!-- 生产环境 -->    <springProfile name="prod">        <appender name="PROD_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">            <file>${PRO_FILE_PATH}</file>            <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">                <fileNamePattern>${PRO_FILE_PATH}.%d{yyyy-MM-dd}.log</fileNamePattern>                <MaxHistory>100</MaxHistory>            </rollingPolicy>            <layout class="ch.qos.logback.classic.PatternLayout">                <pattern>${PATTERN}</pattern>            </layout>        </appender>        <root level="warn">            <appender-ref ref="PROD_FILE" />        </root>    </springProfile></configuration>

3、配置log4j

  • 引用外部配置文件

    去除logback的依赖包,添加log4j2的依赖包

    <dependency>    <groupId>org.springframework.boot</groupId>    <artifactId>spring-boot-starter-web</artifactId>    <exclusions>        <exclusion>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter-logging</artifactId>        </exclusion>    </exclusions></dependency><!-- 使用log4j2 --><dependency>    <groupId>org.springframework.boot</groupId>    <artifactId>spring-boot-starter-log4j2</artifactId></dependency>

    ① 在classpath添加log4j2.xml或者log4j2-spring.xml(spring boot 默认加载)

    ② 自定义配置文件

    <?xml version="1.0" encoding="utf-8"?><configuration>    <properties>        <!-- 文件输出格式 -->        <property name="PATTERN">%d{yyyy-MM-dd HH:mm:ss.SSS} |-%-5level [%thread] %c [%L] -| %msg%n</property>    </properties>    <appenders>        <Console name="CONSOLE" target="system_out">            <PatternLayout pattern="${PATTERN}" />        </Console>    </appenders>    <loggers>        <logger name="com.roncoo.education" level="debug" />        <root level="info">            <appenderref ref="CONSOLE" />        </root>    </loggers></configuration>

4、比较

  • 性能比较:Log4J2Logback 都优于 log4j(不推荐使用)

  • 配置方式:Logback最简洁,spring boot默认,推荐使用

5、配置logging

  • 参考文档

6、致谢名单

  • 冯永伟

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP