SpringBoot之logging基于application多环境配置文件配置日志输出到文件(非spring-logback.xml)

一般情况:日志文件按yyyy-MM-dd分文件夹,%i按单个日志文件大小切割文件并用索引命名。

  1. 开发环境(dev):只输出到控制台,不输出到文件,日志级别为INFO。
  2. 测试环境(test):输出到控制台并且输出到文件,日志级别为INFO,可以配置重启的时候清除日志内容(方便调试)。
  3. 生产环境(prod):不输出到控制台,只输出到文件,日志级别为ERROE(只记录错误日志),禁止重启时清除日志(防止其它人的错误日志被清掉,导致别人无法定位问题)。

pom.xml增加环境配置

	
    <profiles>
        <profile>
            <id>devid>
            <properties>
                <spring.profiles.active>devspring.profiles.active>
            properties>
            <activation>
                
                <activeByDefault>trueactiveByDefault>
            activation>
        profile>

        <profile>
            <id>testid>
            <properties>
                <spring.profiles.active>testspring.profiles.active>
            properties>
        profile>

        <profile>
            <id>prodid>
            <properties>
                <spring.profiles.active>prodspring.profiles.active>
            properties>
        profile>
    profiles>

application.yml

spring:
  application:
    name: '@artifactId@'
  profiles:
    #环境(idea右边栏的maven可以选配置文件的环境)
    active: '@spring.profiles.active@'

application-dev.yml

开发环境配置文件

#按需配置

application-test.yml

测试环境配置文件

logging:
  level:
    #spring根日志级别
    root: error
    #spring web日志级别
    web: error
    #项目日志级别
    com.fu.easycode: info
    #SQL日志打印
    com.fu.easycode.mapper: debug
  file:
    #日志存放路径
    path: ./log/${spring.application.name}/${spring.profiles.active}
    #日志名称
    name: '${logging.file.path}.log'
  charset:
    #控制台编码
    console: UTF-8
    #输出到文件编码
    file: UTF-8
  pattern:
    #控制台日志输出样式
    console: '%clr(%d{${LOG_DATEFORMAT_PATTERN:yyyy-MM-dd HH:mm:ss.SSS}}){faint} %clr(${LOG_LEVEL_PATTERN:-%5p}) %clr(${PID:- }){magenta} %clr(---){faint} %clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}'
    #输出到文件的样式
    file: '%d{${LOG_DATEFORMAT_PATTERN:-yyyy-MM-dd HH:mm:ss.SSS}} ${LOG_LEVEL_PATTERN:-%5p} ${PID:- } --- [%t] %-40.40logger{39} : %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}'
  logback:
    rollingpolicy:
      #重启是否清除日志(推荐测试环境使用)
      clean-history-on-start: true
      #切割日志格式
      file-name-pattern: ${logging.file.path}.%d{yyyy-MM-dd}.%i.log
      #单个日志文件最大大小
      max-file-size: 10MB
      #全部日志文件最大大小
      total-size-cap: 50GB
      #日志存放天数
      max-history: 15

application-prod.yml

生产环境配置文件

logging:
  level:
    #spring根日志级别
    root: error
    #spring web日志级别
    web: error
    #项目日志级别
    com.fu.easycode: error
    #SQL日志打印
    com.fu.easycode.mapper: debug
  file:
    #日志存放路径
    path: ./log/${spring.application.name}/${spring.profiles.active}
    #日志名称
    name: '${logging.file.path}.log'
  charset:
    #输出到文件编码
    file: UTF-8
  pattern:
    #输出到文件的样式
    file: '%d{${LOG_DATEFORMAT_PATTERN:HH:mm:ss}} ${LOG_LEVEL_PATTERN:-%5p} ${PID: } --- [%t] %-40.40logger{39} : %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}'
  logback:
    rollingpolicy:
      #重启是否清除日志,默认:否
      clean-history-on-start: false
      #切割日志格式
      file-name-pattern: ${logging.file.path}.%d{yyyy-MM-dd}.%i.log
      #单个日志文件最大大小
      max-file-size: 10MB
      #全部日志文件最大大小
      total-size-cap: 50GB
      #日志存放天数
      max-history: 15

你可能感兴趣的:(#,Spring,Boot,spring,spring,boot,logback)