中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Springboot內外部logback多環境配置的示例分析

發布時間:2022-01-19 09:10:48 來源:億速云 閱讀:226 作者:小新 欄目:開發技術

這篇文章給大家分享的是有關Springboot內外部logback多環境配置的示例分析的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

一、概述

SpringBoot官方文檔
Springboot 默認讀取的是項目內的 resources 中 logback 配置文件。
如果 classpath(resources) 下有logback-test.xml會優先生效,并且會和其他logback文件同時生效。
Springboot 默認日志級別是DEBUG,所以在logback初始化之前,會有DEBUG日志輸出。

二、項目內外配置

Springboot內外部logback多環境配置的示例分析

注意:logback-{xxx}.xml不能直接放在resources目錄下,否則logback-test.xml會優先生效。

1.application.yml指定 activeprofiles

# Spring配置
spring:
  profiles:
    active: test

2.activeprofiles指定logback-{xxx}.xml

########## logback-{xxx}.xml 文件打包在項目內部 ##########
logging:
   config: classpath:logback/logback-test.xml

########## logback-{xxx}.xml 文件打包在項目外部(去掉classpath) ##########
logging:
  config: /Users/wangfugui/Downloads/logback/logback-test.xml

3.logback-{xxx}.xml

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <!--************************** 測試環境 ****************************-->
    <!-- 日志根路徑(絕對路徑) -->
    <!--    <property name="log.basePath" value="/Users/wangfugui/Downloads/appname"/>-->
    <!-- 日志根路徑(相對路徑),如果使用外部 tomcat,則日志會在bin目錄,需要加../ -->
    <property name="log.basePath" value="logs-test"/>
    <!-- 日志存放路徑 -->
    <property name="log.path" value="/" />
    <!-- 不同的appender,統一日志輸出格式 -->
    <property name="log.pattern" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{20} - [%method,%line] - %msg%n" />

    <!-- 控制臺輸出 -->
    <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>${log.pattern}</pattern>
        </encoder>
    </appender>

    <!-- INFO日志輸出 -->
    <appender name="file_info" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${log.basePath}/${log.path}/sys-info.log</file>
        <!-- 循環政策:基于時間創建日志文件 -->
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!-- 日志文件名格式 -->
            <fileNamePattern>${log.basePath}/${log.path}/sys-info.%d{yyyy-MM-dd}.log</fileNamePattern>
            <!-- 日志最大的歷史 60天 -->
            <maxHistory>60</maxHistory>
        </rollingPolicy>
        <encoder>
            <pattern>${log.pattern}</pattern>
        </encoder>
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <!-- 過濾的級別 -->
            <level>INFO</level>
            <!-- 匹配時的操作:接收(記錄) -->
            <onMatch>ACCEPT</onMatch>
            <!-- 不匹配時的操作:拒絕(不記錄) -->
            <onMismatch>DENY</onMismatch>
        </filter>
    </appender>

    <!-- ERROR日志輸出 -->
    <appender name="file_error" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${log.basePath}/${log.path}/sys-error.log</file>
        <!-- 循環政策:基于時間創建日志文件 -->
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!-- 日志文件名格式 -->
            <fileNamePattern>${log.basePath}/${log.path}/sys-error.%d{yyyy-MM-dd}.log</fileNamePattern>
            <!-- 日志最大的歷史 60天 -->
            <maxHistory>60</maxHistory>
        </rollingPolicy>
        <encoder>
            <pattern>${log.pattern}</pattern>
        </encoder>
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <!-- 過濾的級別 -->
            <level>ERROR</level>
            <!-- 匹配時的操作:接收(記錄) -->
            <onMatch>ACCEPT</onMatch>
            <!-- 不匹配時的操作:拒絕(不記錄) -->
            <onMismatch>DENY</onMismatch>
        </filter>
    </appender>

    <!-- 自定義appender:用戶訪問日志輸出  -->
    <appender name="sys-user" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${log.basePath}/${log.path}/sys-user.log</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!-- 按天回滾 daily -->
            <fileNamePattern>${log.basePath}/${log.path}/sys-user.%d{yyyy-MM-dd}.log</fileNamePattern>
            <!-- 日志最大的歷史 60天 -->
            <maxHistory>60</maxHistory>
        </rollingPolicy>
        <encoder>
            <pattern>${log.pattern}</pattern>
        </encoder>
    </appender>

    <!-- 自定義appender :日志級別控制 -->
    <logger name="sys-user" level="info">
        <appender-ref ref="sys-user"/>
    </logger>

    <!-- 當前系統全局 :日志級別控制  -->
    <logger name="com.example" level="info" />

    <!-- 第三方系統:Spring日志級別控制  -->
    <logger name="org.springframework" level="warn" />
    <!-- 第三方系統:關閉kafka日志 -->
    <!--<logger name="org.apache.kafka" level="off"/>-->

    <!-- 單獨指定控制臺打印級別 -->
    <root level="info">
        <appender-ref ref="console" />
    </root>

    <!-- 指定上面appender的日志打印級別 -->
    <root level="info">
        <appender-ref ref="file_info" />
        <appender-ref ref="file_error" />
    </root>
</configuration>

三、使用自定義appender

使用Lombok
Lombok 內置 @Slf4j 、@Log4j2 兩種日志注解。

@Log4j2(topic = "sys-user")
@Slf4j(topic = "sys-user")

不使用Lombok

Logger logger = LoggerFactory.getLogger("sys-user");

四、logback查找配置源碼

org.springframework.boot.logging.logback.LogbackLoggingSystem

    protected String[] getStandardConfigLocations() {
        return new String[]{"logback-test.groovy", "logback-test.xml", "logback.groovy", "logback.xml"};
    }

感謝各位的閱讀!關于“Springboot內外部logback多環境配置的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

泸定县| 桦南县| 安阳县| 同德县| 修武县| 瓮安县| 本溪| 密山市| 台中市| 沁源县| 九台市| 中宁县| 大庆市| 大冶市| 湘潭市| 章丘市| 仙游县| 武隆县| 宁城县| 泸水县| 平山县| 湖北省| 博罗县| 连平县| 永仁县| 富宁县| 旅游| 循化| 宁国市| 烟台市| 通州市| 辽阳市| 苏州市| 宁夏| 淮阳县| 中牟县| 东源县| 嘉鱼县| 怀仁县| 湟中县| 寻乌县|