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并發(fā)編程中的CyclicBarrier使用解析
這篇文章主要介紹了Java并發(fā)編程中的CyclicBarrier使用解析,CyclicBarrier從字面意思上來看,循環(huán)柵欄,這篇文章就來分析下是到底是如何實現(xiàn)循環(huán)和柵欄的,需要的朋友可以參考下2023-12-12Mybatis-Plus可能導(dǎo)致死鎖的問題分析及解決辦法
這篇文章給大家主要介紹了Mybatis-Plus可能導(dǎo)致死鎖的問題分析及解決辦法,文中通過代碼示例給大家介紹的非常詳細,具有一定的參考價值,需要的朋友可以參考下2023-12-12Java中IO流的BufferedOutputStream和FileOutputStream對比
這篇文章主要介紹了Java中IO流的BufferedOutputStream和FileOutputStream對比,不帶緩沖的操作,每讀一個字節(jié)就要寫入一個字節(jié),由于涉及磁盤的IO操作相比內(nèi)存的操作要慢很多,所以在讀寫的字節(jié)比較少的情況下,效率比較低,需要的朋友可以參考下2023-07-07數(shù)據(jù)結(jié)構(gòu)與算法之并查集(不相交集合)
并查集是一種挺高效的數(shù)據(jù)結(jié)構(gòu)。實現(xiàn)簡單,只是所有元素統(tǒng)一遵從一個規(guī)律所以讓辦事情的效率高效起來。這篇文章主要介紹了數(shù)據(jù)結(jié)構(gòu)與算法——并查集(不相交集合),需要的朋友可以參考下2019-11-11java基于正則提取字符串中的數(shù)字功能【如提取短信中的驗證碼】
這篇文章主要介紹了java基于正則提取字符串中的數(shù)字功能,可用于提取短信中的驗證碼,涉及java基于正則的字符串匹配相關(guān)操作技巧,需要的朋友可以參考下2017-01-01java實現(xiàn)簡單網(wǎng)絡(luò)象棋游戲
這篇文章主要為大家詳細介紹了java實現(xiàn)簡單網(wǎng)絡(luò)象棋游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-12-12springboot引用kettle實現(xiàn)對接oracle數(shù)據(jù)的示例代碼
這篇文章主要介紹了springboot引用kettle實現(xiàn)對接oracle數(shù)據(jù),其實kettle集成到springboot里面沒有多少代碼,這個功能最主要的還是ktr文件的編寫,只要ktr編寫好了,放到指定文件夾下,寫個定時任務(wù)就完事了,需要的朋友可以參考下2022-12-12