美文网首页
SpringBoot配置logback日志文件

SpringBoot配置logback日志文件

作者: 轻轻敲醒沉睡的心灵 | 来源:发表于2021-06-11 10:27 被阅读0次

    我使用的是SpringBoot2.X,默认的日志组件是logback,为了更好地使用logback,需要做一些简单配置。

    1. 基础配置

    • yml文件配置
    # 2.log
    logging:
      # logback.xml配置文件的位置
      config: classpath:logback-spring.xml
    
    • logback-spring.xml文件放到resource目录下
      image.png
      注意:文件名字定义为logback-spring.xml是为了能够配置不同的环境设置不同的日志

    2. logback-spring.xml配置文件

    配置文件的跟标签是configuration,它下面有propertycontextNameappenderrootlogger等标签

    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE xml>
    <!-- 日志级别从低到高分为TRACE < DEBUG < INFO < WARN < ERROR < FATAL,如果设置为WARN,则低于WARN的信息都不会输出 -->
    <!-- scan:当此属性设置为true时,配置文件如果发生改变,将会被重新加载,默认值为true -->
    <!-- scanPeriod:设置监测配置文件是否有修改的时间间隔,如果没有给出时间单位,默认单位是毫秒。当scan为true时,此属性生效。默认的时间间隔为1分钟。 -->
    <!-- debug:当此属性设置为true时,将打印出logback内部日志信息,实时查看logback运行状态。默认值为false。 -->
    <configuration scan="true" scanPeriod="10 seconds">
    
        <property name="CONTEXT_NAME" value="client1" />
        <property name="LOG_PATH" value="logs" />
        <property name="MAX_FILE_SIZE" value="100MB" />
        <property name="MAX_HISTORY" value="30" />
        <!--读取配置中心的属性 -->
        <!-- <springProperty scope="context" name="LOG_PATH_NAME" source="logging.file.name"/> -->
    
        <contextName>${CONTEXT_NAME}</contextName>
        
        <!--输出到控制台 -->
        <!-- %m输出的信息,%p日志级别,%t线程名,%d日期,%c类的全名,%-5level:级别从左显示5个字符宽度,%logger{50}:表示logger名字最长50个字符,否则按照句点分割,%msg:日志消息,%i索引【从数字0开始递增】 -->
        <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
            <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
                <level>INFO</level>
            </filter>
            <encoder>
                <!--在控制台使用caller方式打印堆栈信息有超链接,使用replace去掉换行符-->
                <Pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %replace(%caller{1}){'\t|Caller.{1}0|\r\n', ''} -- %msg%n</Pattern>
                <!-- 设置字符集 -->
                <charset>UTF-8</charset>
            </encoder>
        </appender>
    
        <!--所有日志输出到文件 -->
        <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
            <!--日志名,指定最新的文件名,其他文件名使用FileNamePattern -->
            <File>${LOG_PATH}/${CONTEXT_NAME}.log</File>
            <!--日志文件输出格式 -->
            <encoder>
                 <!--%logger{50}:表示logger名字最长50个字符,否则按照句点分割。
                  %M:输出执行日志请求的方法名。尽量避免使用,除非执行速度不造成任何问题。
                  %line:输出执行日志请求的行号。尽量避免使用,除非执行速度不造成任何问题。 -->
                <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{50}.%M\(%line\) -- %msg%n</pattern>
                <charset>UTF-8</charset> <!-- 设置字符集 -->
            </encoder>
            <!-- 日志记录器的滚动策略,按日期,按大小记录 -->
            <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                <!-- 日志归档 后面可以加.zip -->
                <fileNamePattern>${LOG_PATH}/${CONTEXT_NAME}-%d{yyyy-MM-dd}-%i.log</fileNamePattern>
                <!--日志文件保留天数 -->
                <maxHistory>${MAX_HISTORY}</maxHistory>
                <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                    <!--文件达到 最大时会被压缩和切割 -->
                    <maxFileSize>${MAX_FILE_SIZE}</maxFileSize>
                </timeBasedFileNamingAndTriggeringPolicy>
            </rollingPolicy>
        </appender>
    
        <!-- ERROR 日志 -->
        <appender name="ERROR_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
            <!--日志名,指定最新的文件名,其他文件名使用FileNamePattern -->
            <File>${LOG_PATH}/${CONTEXT_NAME}-error.log</File>
            <encoder>
                <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{50}.%M\(%line\) -- %msg%n</pattern>
                <charset>UTF-8</charset> <!-- 此处设置字符集 -->
            </encoder>
            <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                <fileNamePattern>${LOG_PATH}/${CONTEXT_NAME}_error-%d{yyyy-MM-dd}.log</fileNamePattern>
                <maxHistory>${MAX_HISTORY}</maxHistory>
            </rollingPolicy>
            <!-- 此日志文件只记录ERROR级别的 -->
            <filter class="ch.qos.logback.classic.filter.LevelFilter">
                <!-- 指定级别 -->
                <level>ERROR</level>
                <!-- onMatch:意思是>=指定级别 接受 -->
                <onMatch>ACCEPT</onMatch>
                <!-- onMismatch:意思是<指定级别 拒绝 -->
                <onMismatch>DENY</onMismatch>
            </filter>
        </appender>
    
        <!-- 异步日志输出看情况配置 -->
        <appender name="ASYNC_FILE" class="ch.qos.logback.classic.AsyncAppender">
            <!-- 更改默认的队列的深度,该值会影响性能.默认值为256 -->
            <queueSize>512</queueSize>
            <!-- 添加附加的appender,最多只能添加一个 -->
            <appender-ref ref="FILE" />
        </appender>
        <appender name="ASYNC_ERROR_FILE" class="ch.qos.logback.classic.AsyncAppender">
            <!-- 更改默认的队列的深度,该值会影响性能.默认值为256 -->
            <queueSize>512</queueSize>
            <!-- 添加附加的appender,最多只能添加一个 -->
            <appender-ref ref="ERROR_FILE" />
        </appender>
        
        <!-- 统一配置日志输出,root标签和logger标签,如果这开启了就把不同环境的关上 -->
        <!-- root标签:相当于开关,只有把定义的appender添加到这里 才会生效有日志 -->
        <!-- <root level="INFO">
            <appender-ref ref="CONSOLE" />
            <appender-ref ref="ASYNC_FILE" />
            <appender-ref ref="ASYNC_ERROR_FILE" />
        </root> -->
        <!-- logger标签:用来设置某一个包或者具体的某一个类的日志打印级别 -->
        <!-- <logger name="com.test.springboot.admin" level="DEBUG" /> -->
    
    
        <!-- 配置不同环境的日志输出,root标签和logger标签 -->
        <springProfile name="dev"> 
            <logger name="com.test.dao" level="debug"/> 
            <root level="DEBUG"> 
                <appender-ref ref="CONSOLE" /> 
                <!-- <appender-ref ref="ASYNC_FILE" />  -->
                <!-- <appender-ref ref="ASYNC_ERROR_FILE" />  -->
            </root> 
        </springProfile>
    
        <!-- <springProfile name="prod"> 
            <root level="INFO"> 
                <appender-ref ref="ASYNC_FILE" /> 
                <appender-ref ref="ASYNC_ERROR_FILE" /> 
            </root>
        </springProfile> -->
    </configuration>
    

    需要注意以下几点:

      1. property是为了配置统一属性,为了好修改
      1. appender标签是配置具体日志内容和方式,不要搞错
      1. root标签是开关,一定要配置。要不配置统一root标签,要不配置环境中的root标签。开启1个就行
      1. 细粒度配置日志级别,使用logger标签

    相关文章

      网友评论

          本文标题:SpringBoot配置logback日志文件

          本文链接:https://www.haomeiwen.com/subject/nevmeltx.html