SpringBoot多環境配置self4j + logback 以及遇到的問題

SpringBoot Starter 包下面默認已經集成了Self4J + LogBack
圖片描述spring

問題

你們都知道SpringBoot能夠使用yml和properties兩種配置方式。可是這邊有一個問題,在使用yml方式配置logback的時候,不能用LogHome指定它的路徑。如:app

logging:
  config:
    classpath: config/logback-spring:xml
  path: log
  file: loginfo

<property name="LOG_HOME" value="${LOG_PATH}/${LOG_FILE}" />

這樣作會致使在你的目錄下生成一個loginfo的文件,而沒有路徑。可是若是你用properties配置文件,就不會有這個問題。我被困擾了很久···。spa

yml多環境配置logback

首先是主要的配置文件:application.yml

spring:
  profiles:
    active: dev  //這邊表明你須要激活哪一個環境

建立你須要的環境配置文件,

在同一目錄下:如application-dev.yml線程

在resource根目錄下建立logback配置文件

<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="true">
    <!-- 項目名稱 -->
    <property name="PROJECT_NAME" value="projectmanage"/>

    <!--定義日誌文件的存儲地址 勿在 LogBack 的配置中使用相對路徑-->
    <property name="LOG_HOME" value="${catalina.base:-.}/logs"/>

    <!-- 控制檯輸出 -->
    <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
        <withJansi>true</withJansi>
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <!--格式化輸出:%d表示日期,%thread表示線程名,%-5level:級別從左顯示5個字符寬度%msg:日誌消息,%n是換行符-->
            <pattern>[%d{yyyy-MM-dd HH:mm:ss.SSS}] [%thread] %highlight([%-5level] %logger{50} - %msg%n)</pattern>
            <charset>UTF-8</charset>
        </encoder>
    </appender>

    <!-- 系統錯誤日誌文件 -->
    <appender name="SYSTEM_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <!-- 過濾器,只打印ERROR級別的日誌 -->
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>ERROR</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>DENY</onMismatch>
        </filter>
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <!--日誌文件輸出的文件名-->
            <FileNamePattern>${LOG_HOME}/${PROJECT_NAME}.system_error.%d{yyyy-MM-dd}.%i.log</FileNamePattern>
            <!--日誌文件保留天數-->
            <MaxHistory>15</MaxHistory>
            <!--日誌文件最大的大小-->
            <MaxFileSize>10MB</MaxFileSize>
        </rollingPolicy>

        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <!--格式化輸出:%d表示日期,%thread表示線程名,%-5level:級別從左顯示5個字符寬度%msg:日誌消息,%n是換行符-->
            <pattern>[%d{yyyy-MM-dd HH:mm:ss.SSS}] [%thread] [%-5level] %logger{50} - %msg%n</pattern>
            <charset>UTF-8</charset>
        </encoder>
    </appender>
    <logger name="system_error" additivity="true">
        <appender-ref ref="SYSTEM_FILE"/>
    </logger>

    <!-- 本身打印的日誌文件,用於記錄重要日誌信息 -->
    <appender name="MY_INFO_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <!-- 過濾器,只打印ERROR級別的日誌 -->
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>INFO</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>DENY</onMismatch>
        </filter>
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <!--日誌文件輸出的文件名-->
            <FileNamePattern>${LOG_HOME}/${PROJECT_NAME}.my_info.%d{yyyy-MM-dd}.%i.log</FileNamePattern>
            <!--日誌文件保留天數-->
            <MaxHistory>15</MaxHistory>
            <!--日誌文件最大的大小-->
            <MaxFileSize>10MB</MaxFileSize>
        </rollingPolicy>

        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <!--格式化輸出:%d表示日期,%thread表示線程名,%-5level:級別從左顯示5個字符寬度%msg:日誌消息,%n是換行符-->
            <pattern>[%d{yyyy-MM-dd HH:mm:ss.SSS}] [%thread] [%-5level] %logger{50} - %msg%n</pattern>
            <charset>UTF-8</charset>
        </encoder>
    </appender>
    <logger name="my_info" additivity="true" level="info">
        <appender-ref ref="MY_INFO_FILE"/>
    </logger>

    

    <!-- 開發環境下的日誌配置  這邊就是你開發環境的配置-->
    <springProfile name="dev">
        <root level="INFO">
            <appender-ref ref="CONSOLE"/>
            <appender-ref ref="SYSTEM_FILE"/>
        </root>
    </springProfile>

    <!-- 生產環境下的日誌配置 這邊就是你生產環境的配置-->
    <springProfile name="prod">
        <root level="INFO">
            <appender-ref ref="SYSTEM_FILE"/>
        </root>
    </springProfile>
</configuration>
相關文章
相關標籤/搜索