欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Springboot內(nèi)外部logback多環(huán)境配置詳解

 更新時間:2022年01月18日 16:12:20   作者:碼上富貴  
本文主要介紹了Springboot內(nèi)外部logback多環(huán)境配置詳解,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

一、概述

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

二、項目內(nèi)外配置

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

1.application.yml指定 activeprofiles

# Spring配置
spring:
  profiles:
    active: test

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

########## logback-{xxx}.xml 文件打包在項目內(nèi)部 ##########
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>
? ? <!--************************** 測試環(huán)境 ****************************-->
? ? <!-- 日志根路徑(絕對路徑) -->
? ? <!-- ? ?<property name="log.basePath" value="/Users/wangfugui/Downloads/appname"/>-->
? ? <!-- 日志根路徑(相對路徑),如果使用外部 tomcat,則日志會在bin目錄,需要加../ -->
? ? <property name="log.basePath" value="logs-test"/>
? ? <!-- 日志存放路徑 -->
? ? <property name="log.path" value="/" />
? ? <!-- 不同的appender,統(tǒng)一日志輸出格式 -->
? ? <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>
? ? ? ? <!-- 循環(huán)政策:基于時間創(chuàng)建日志文件 -->
? ? ? ? <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>
? ? ? ? <!-- 循環(huán)政策:基于時間創(chuàng)建日志文件 -->
? ? ? ? <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>

? ? <!-- 當(dāng)前系統(tǒng)全局 :日志級別控制 ?-->
? ? <logger name="com.example" level="info" />

? ? <!-- 第三方系統(tǒng):Spring日志級別控制 ?-->
? ? <logger name="org.springframework" level="warn" />
? ? <!-- 第三方系統(tǒng):關(guān)閉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 內(nèi)置 @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"};
    }

五、案例源碼

github : https://github.com/duke147/springboot-logback.git

到此這篇關(guān)于Springboot內(nèi)外部logback多環(huán)境配置詳解的文章就介紹到這了,更多相關(guān)Springboot logback多環(huán)境配置內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 淺談Java面向?qū)ο笾畠?nèi)部類

    淺談Java面向?qū)ο笾畠?nèi)部類

    內(nèi)部類是一個非常有用的特性但又比較難理解使用的特性,我們從外面看是非常容易理解的,無非就是在一個類的內(nèi)部在定義一個類。其實使用內(nèi)部類最大的優(yōu)點就在于它能夠非常好的解決多重繼承的問題
    2021-06-06
  • 最新評論